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

您的位置:首頁技術(shù)文章
文章詳情頁

MyBatis中resultMap和resultType的區(qū)別詳解

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

總結(jié)

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

resultType和resultMap功能類似 ,都是返回對(duì)象信息 ,但是resultMap要更強(qiáng)大一些 ,可自定義。因?yàn)閞esultMap要配置一下,表和類的一一對(duì)應(yīng)關(guān)系,所以說就算你的字段名和你的實(shí)體類的屬性名不一樣也沒關(guān)系,都會(huì)給你映射出來,但是,resultType就比較雞肋了,必須字段名一樣,比如說 cId和c_id 這種的都不能映射 。下面介紹幾個(gè)常用的映射關(guān)系:

MyBatis中resultMap和resultType的區(qū)別詳解

MyBatis中resultMap和resultType的區(qū)別詳解

單表查詢: resultMap:當(dāng)使用resultMap做SQL語句返回結(jié)果類型處理時(shí),通常需要在mapper.xml中定義resultMap進(jìn)行pojo和相應(yīng)表字段的對(duì)應(yīng)。

訂單查詢關(guān)聯(lián)用戶的resultMap

將整個(gè)查詢的結(jié)果映射到cn.itcast.mybatis.po.Orders中

<resultMap type='cn.itcast.mybatis.po.Orders' id='OrdersUserResultMap'> <!-- 配置映射的訂單信息 --> <!-- id:指定查詢列中的唯 一標(biāo)識(shí),訂單信息的中的唯 一標(biāo)識(shí),如果有多個(gè)列組成唯一標(biāo)識(shí),配置多個(gè)id column:訂單信息的唯 一標(biāo)識(shí) 列 property:訂單信息的唯 一標(biāo)識(shí) 列所映射到Orders中哪個(gè)屬性 --> <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>

關(guān)聯(lián)查詢(一對(duì)一):resultMap對(duì)于一對(duì)一表連接的處理方式通常為在主表的pojo中添加嵌套另一個(gè)表的pojo,然后在mapper.xml中采用association節(jié)點(diǎn)元素進(jìn)行對(duì)另一個(gè)表的連接處理。例如

訂單查詢關(guān)聯(lián)用戶的resultMap

將整個(gè)查詢的結(jié)果映射到cn.itcast.mybatis.po.Orders中

<resultMap type='cn.itcast.mybatis.po.Orders' id='OrdersUserResultMap'> <!-- 配置映射的訂單信息 --> <!-- id:指定查詢列中的唯 一標(biāo)識(shí),訂單信息的中的唯 一標(biāo)識(shí),如果有多個(gè)列組成唯一標(biāo)識(shí),配置多個(gè)id column:訂單信息的唯 一標(biāo)識(shí) 列 property:訂單信息的唯 一標(biāo)識(shí) 列所映射到Orders中哪個(gè)屬性 --> <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/> <!-- 配置映射的關(guān)聯(lián)的用戶信息 --> <!-- association:用于映射關(guān)聯(lián)查詢單個(gè)對(duì)象的信息 property:要將關(guān)聯(lián)查詢的用戶信息映射到Orders中哪個(gè)屬性 --> <association property='user' javaType='cn.itcast.mybatis.po.User'> <!-- id:關(guān)聯(lián)查詢用戶的唯 一標(biāo)識(shí) column:指定唯 一標(biāo)識(shí)用戶信息的列 javaType:映射到user的哪個(gè)屬性 --> <id column='user_id' property='id'/> <result column='username' property='username'/> <result column='sex' property='sex'/> <result column='address' property='address'/> </association></resultMap>

關(guān)聯(lián)查詢(一對(duì)多):resultMap的處理方式為在訂單表數(shù)據(jù)的pojo中添加一個(gè)list,list中為訂單明細(xì)表的屬性,在mapper.xml中采用如下的處理方式:

訂單及訂單明細(xì)的resultMap

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

<resultMap type='cn.itcast.mybatis.po.Orders' extends='OrdersUserResultMap'> <!-- 訂單信息 --> <!-- 用戶信息 --> <!-- 使用extends繼承,不用在中配置訂單信息和用戶信息的映射 --> <!-- 訂單明細(xì)信息 一個(gè)訂單關(guān)聯(lián)查詢出了多條明細(xì),要使用collection進(jìn)行映射 collection:對(duì)關(guān)聯(lián)查詢到多條記錄映射到集合對(duì)象中 property:將關(guān)聯(lián)查詢到多條記錄映射到cn.itcast.mybatis.po.Orders哪個(gè)屬性 ofType:指定映射到list集合屬性中pojo的類型 --> <collection property='orderdetails' ofType='cn.itcast.mybatis.po.Orderdetail'> <!-- id:訂單明細(xì)唯 一標(biāo)識(shí) property:要將訂單明細(xì)的唯 一標(biāo)識(shí) 映射到cn.itcast.mybatis.po.Orderdetail的哪個(gè)屬性 --> <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:

作用:將關(guān)聯(lián)查詢信息映射到一個(gè)pojo對(duì)象中

場(chǎng)合:為了方便查詢關(guān)聯(lián)查詢可以使用assocation將關(guān)聯(lián)查詢信息映射為用戶對(duì)象的pojo屬性中。

比如:查詢訂單及關(guān)聯(lián)用戶信息使用resultType無法查詢結(jié)果映射到pojo對(duì)象的pojo屬性中,根據(jù)對(duì)結(jié)構(gòu)集查詢遍歷的需要選擇使用resultType還是resultMap。

collection:

作用:將關(guān)聯(lián)查詢信息映射到一個(gè)list集合中。場(chǎng)合:為了方便查詢遍歷關(guān)聯(lián)信息可以使用cellection將關(guān)聯(lián)信息映射到list集合中。比如:查詢用戶權(quán)限范圍模塊及模塊下的菜單,可使用collection將模塊映射到模塊list中將菜單列表映射到模塊對(duì)象的菜單list屬性中,這樣做的目的也是方便對(duì)查詢結(jié)果集進(jìn)行遍歷如果使用resultType無法將查詢結(jié)果映射到list集合中

到此這篇關(guān)于mybaties中resultMap和resultType的區(qū)別詳解的文章就介紹到這了,更多相關(guān)mybaties中resultMap和resultType的區(qū)別內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

相關(guān)文章:
主站蜘蛛池模板: 国产在线观看一区 | 在线精品视频播放 | 91久久在线| 欧美白人和黑人xxxx猛交视频 | www中文字幕 | 亚洲视频免费在线观看 | 亚洲视频在线观看地址 | 在线观看中文字幕一区 | 国产亚洲自拍一区 | 久久精品国产这里是免费 | 亚洲欧美在线一区二区 | 亚洲男女在线 | 91精品国产91久久久久久青草 | 免费黄色网址在线播放 | 在线观看人成午夜影片 | 中国人免费观看高清在线观看二区 | 三级韩国一区久久二区综合 | 久久有这有精品在线观看 | 国产高清一区二区三区 | 一区二区在线播放福利视频 | 亚洲国产99在线精品一区二区 | 97免费视频免费视频 | 一级美女片 | 26uuu欧美日韩国产 | 最新亚洲情黄在线网站无广告 | 成人黄色在线免费观看 | 亚洲另类激情综合偷自拍图 | 岛国大片在线播放免费 | 久久久美女视频 | 午夜不卡视频 | 99视频99| 日韩欧美中文字幕在线观看 | 欧美成人三级网站在线观看 | 国产成人成人一区二区 | 亚洲3p| 国产人成免费视频 | 黑色丝袜美美女被躁视频 | 欧美性猛交xxxxxxxx软件 | 免费一级片网站 | 国产三级视频网站 | 奇米色88欧美一区二区 |