国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

MyBatis中resultMap和resultType的區別詳解

瀏覽:98日期:2023-10-23 16:52:46

總結

基本映射 :(resultType)使用resultType進行輸出映射,只有查詢出來的列名和pojo中的屬性名一致,該列才可以映射成功。(數據庫,實體,查詢字段,這些全部都得一一對應)高級映射 :(resultMap) 如果查詢出來的列名和pojo的屬性名不一致,通過定義一個resultMap對列名和pojo屬性名之間作一個映射關系。(高級映射,字段名稱可以不一致,通過映射來實現

resultType和resultMap功能類似 ,都是返回對象信息 ,但是resultMap要更強大一些 ,可自定義。因為resultMap要配置一下,表和類的一一對應關系,所以說就算你的字段名和你的實體類的屬性名不一樣也沒關系,都會給你映射出來,但是,resultType就比較雞肋了,必須字段名一樣,比如說 cId和c_id 這種的都不能映射 。下面介紹幾個常用的映射關系:

MyBatis中resultMap和resultType的區別詳解

MyBatis中resultMap和resultType的區別詳解

單表查詢: resultMap:當使用resultMap做SQL語句返回結果類型處理時,通常需要在mapper.xml中定義resultMap進行pojo和相應表字段的對應。

訂單查詢關聯用戶的resultMap

將整個查詢的結果映射到cn.itcast.mybatis.po.Orders中

<resultMap type='cn.itcast.mybatis.po.Orders' id='OrdersUserResultMap'> <!-- 配置映射的訂單信息 --> <!-- id:指定查詢列中的唯 一標識,訂單信息的中的唯 一標識,如果有多個列組成唯一標識,配置多個id column:訂單信息的唯 一標識 列 property:訂單信息的唯 一標識 列所映射到Orders中哪個屬性 --> <id column='id' property='id'/> <result column='user_id' property='userId'/> <result column='number' property='number'/> <result column='createtime' property='createtime'/> <result column='note' property='note'/> </resultMap>

關聯查詢(一對一):resultMap對于一對一表連接的處理方式通常為在主表的pojo中添加嵌套另一個表的pojo,然后在mapper.xml中采用association節點元素進行對另一個表的連接處理。例如

訂單查詢關聯用戶的resultMap

將整個查詢的結果映射到cn.itcast.mybatis.po.Orders中

<resultMap type='cn.itcast.mybatis.po.Orders' id='OrdersUserResultMap'> <!-- 配置映射的訂單信息 --> <!-- id:指定查詢列中的唯 一標識,訂單信息的中的唯 一標識,如果有多個列組成唯一標識,配置多個id column:訂單信息的唯 一標識 列 property:訂單信息的唯 一標識 列所映射到Orders中哪個屬性 --> <id column='id' property='id'/> <result column='user_id' property='userId'/> <result column='number' property='number'/> <result column='createtime' property='createtime'/> <result column='note' property=note/> <!-- 配置映射的關聯的用戶信息 --> <!-- association:用于映射關聯查詢單個對象的信息 property:要將關聯查詢的用戶信息映射到Orders中哪個屬性 --> <association property='user' javaType='cn.itcast.mybatis.po.User'> <!-- id:關聯查詢用戶的唯 一標識 column:指定唯 一標識用戶信息的列 javaType:映射到user的哪個屬性 --> <id column='user_id' property='id'/> <result column='username' property='username'/> <result column='sex' property='sex'/> <result column='address' property='address'/> </association></resultMap>

關聯查詢(一對多):resultMap的處理方式為在訂單表數據的pojo中添加一個list,list中為訂單明細表的屬性,在mapper.xml中采用如下的處理方式:

訂單及訂單明細的resultMap

使用extends繼承,不用在中配置訂單信息和用戶信息的映射

<resultMap type='cn.itcast.mybatis.po.Orders' extends='OrdersUserResultMap'> <!-- 訂單信息 --> <!-- 用戶信息 --> <!-- 使用extends繼承,不用在中配置訂單信息和用戶信息的映射 --> <!-- 訂單明細信息 一個訂單關聯查詢出了多條明細,要使用collection進行映射 collection:對關聯查詢到多條記錄映射到集合對象中 property:將關聯查詢到多條記錄映射到cn.itcast.mybatis.po.Orders哪個屬性 ofType:指定映射到list集合屬性中pojo的類型 --> <collection property='orderdetails' ofType='cn.itcast.mybatis.po.Orderdetail'> <!-- id:訂單明細唯 一標識 property:要將訂單明細的唯 一標識 映射到cn.itcast.mybatis.po.Orderdetail的哪個屬性 --> <id column='orderdetail_id' property='id'/> <result column='items_id' property='itemsId'/> <result column='items_num' property='itemsNum'/> <result column='orders_id' property='ordersId'/> </collection></resultMap>

association:

作用:將關聯查詢信息映射到一個pojo對象中

場合:為了方便查詢關聯查詢可以使用assocation將關聯查詢信息映射為用戶對象的pojo屬性中。

比如:查詢訂單及關聯用戶信息使用resultType無法查詢結果映射到pojo對象的pojo屬性中,根據對結構集查詢遍歷的需要選擇使用resultType還是resultMap。

collection:

作用:將關聯查詢信息映射到一個list集合中。場合:為了方便查詢遍歷關聯信息可以使用cellection將關聯信息映射到list集合中。比如:查詢用戶權限范圍模塊及模塊下的菜單,可使用collection將模塊映射到模塊list中將菜單列表映射到模塊對象的菜單list屬性中,這樣做的目的也是方便對查詢結果集進行遍歷如果使用resultType無法將查詢結果映射到list集合中

到此這篇關于mybaties中resultMap和resultType的區別詳解的文章就介紹到這了,更多相關mybaties中resultMap和resultType的區別內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 欧美精品一区视频 | 欧美一级毛片俄罗斯 | 午夜在线播放免费人成无 | 黄篇网址| 在线观看欧美亚洲日本专区 | 日本免费小视频 | 日本护士视频xxxxxwww | 亚洲欧美自拍偷拍 | 精品久久久久久久高清 | 国产三级网 | 国产精品久久国产精品99 | 91久久精品国产91久久性色也 | 欧美精品久久久久久久影视 | 在线精品日韩一区二区三区 | 亚洲精品手机在线 | 久久久久亚洲精品中文字幕 | 亚洲一区成人 | 国产欧美一区二区精品久久久 | 美国全免费特一级毛片 | 久久精品国产99久久香蕉 | 久久综合免费视频 | 亚洲欧美一级久久精品 | 尹人成人 | 亚洲品质自拍视频网站 | 韩国精品一区二区三区四区五区 | 中文字幕成人免费高清在线视频 | 足恋玩丝袜脚视频免费网站 | 波多野结衣一区二区 | 成人欧美精品久久久久影院 | 亚洲男人在线 | 免费播放美女一级毛片 | 成年人精品视频 | 国产一区二区久久久 | 欧美成人免费午夜影视 | 亚洲日韩中文字幕天堂不卡 | 三级韩国一区久久二区综合 | 美国欧美一级毛片 | 男女午夜性爽快免费视频不卡 | 亚洲精品成人一区二区www | 视频一二三区 | 欧美aaaaaa|