MyBatis中resultMap和resultType的區(qū)別詳解
總結(jié)
基本映射 :(resultType)使用resultType進(jìn)行輸出映射,只有查詢出來(lái)的列名和pojo中的屬性名一致,該列才可以映射成功。(數(shù)據(jù)庫(kù),實(shí)體,查詢字段,這些全部都得一一對(duì)應(yīng))高級(jí)映射 :(resultMap) 如果查詢出來(lái)的列名和pojo的屬性名不一致,通過(guò)定義一個(gè)resultMap對(duì)列名和pojo屬性名之間作一個(gè)映射關(guān)系。(高級(jí)映射,字段名稱可以不一致,通過(guò)映射來(lái)實(shí)現(xiàn)
resultType和resultMap功能類似 ,都是返回對(duì)象信息 ,但是resultMap要更強(qiáng)大一些 ,可自定義。因?yàn)閞esultMap要配置一下,表和類的一一對(duì)應(yīng)關(guān)系,所以說(shuō)就算你的字段名和你的實(shí)體類的屬性名不一樣也沒(méi)關(guān)系,都會(huì)給你映射出來(lái),但是,resultType就比較雞肋了,必須字段名一樣,比如說(shuō) cId和c_id 這種的都不能映射 。下面介紹幾個(gè)常用的映射關(guān)系:
單表查詢: resultMap:當(dāng)使用resultMap做SQL語(yǔ)句返回結(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" id="OrdersAndOrderDetailResultMap" 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無(wú)法查詢結(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無(wú)法將查詢結(jié)果映射到list集合中
到此這篇關(guān)于mybaties中resultMap和resultType的區(qū)別詳解的文章就介紹到這了,更多相關(guān)mybaties中resultMap和resultType的區(qū)別內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 三分鐘讀懂mybatis中resultMap和resultType區(qū)別
- Java?MyBatis傳出參數(shù)resultType和resultMap解讀
- MyBatis中resultType和parameterType和resultMap使用總結(jié)
- MyBatis標(biāo)簽之Select?resultType和resultMap詳解
- Mybatis開發(fā)要點(diǎn)-resultType和resultMap有什么區(qū)別詳解
- 詳解MyBatis resultType與resultMap中的幾種返回類型
- MyBatis中關(guān)于resultType和resultMap的區(qū)別介紹
- 深入理解Mybatis中的resultType和resultMap
- Mybatis中的resultType和resultMap查詢操作實(shí)例詳解
- Mybatis返回值(resultType&resultMap)的具體使用
相關(guān)文章
Java中HashMap和TreeMap的區(qū)別深入理解
首先介紹一下什么是Map。在數(shù)組中我們是通過(guò)數(shù)組下標(biāo)來(lái)對(duì)其內(nèi)容索引的,而在Map中我們通過(guò)對(duì)象來(lái)對(duì)對(duì)象進(jìn)行索引,用來(lái)索引的對(duì)象叫做key,其對(duì)應(yīng)的對(duì)象叫做value2012-12-12Spring Boot中使用jdbctemplate 操作MYSQL數(shù)據(jù)庫(kù)實(shí)例
本篇文章主要介紹了Spring Boot中使用jdbctemplate 操作MYSQL數(shù)據(jù)庫(kù)實(shí)例,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-04-04最簡(jiǎn)單的在IntelliJ IDEA導(dǎo)入一個(gè)本地項(xiàng)目教程(圖文)
這篇文章主要介紹了最簡(jiǎn)單的在IntelliJ IDEA導(dǎo)入一個(gè)本地項(xiàng)目教程(圖文),文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08Springboot項(xiàng)目Maven依賴沖突的問(wèn)題解決
使用Spring Boot和Maven進(jìn)行項(xiàng)目開發(fā)時(shí),依賴沖突是一個(gè)常見(jiàn)的問(wèn)題,本文就來(lái)介紹一下Springboot項(xiàng)目Maven依賴沖突的問(wèn)題解決,具有一定的參考價(jià)值,感興趣的可以了解一下2024-07-07Java數(shù)據(jù)結(jié)構(gòu)之棧與綜合計(jì)算器的實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了Java數(shù)據(jù)結(jié)構(gòu)中棧與綜合計(jì)算器的實(shí)現(xiàn),文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解一下2022-10-10Java中String、StringBuffer和StringBuilder的區(qū)別與使用場(chǎng)景
在Java編程中,String、StringBuffer和StringBuilder是用于處理字符串的常見(jiàn)類,它們?cè)诳勺冃?、線程安全性和性能方面有所不同,具有一定的參考價(jià)值,感興趣的可以了解一下2024-05-05在Android的應(yīng)用中實(shí)現(xiàn)網(wǎng)絡(luò)圖片異步加載的方法
這篇文章主要介紹了在Android的應(yīng)用中實(shí)現(xiàn)網(wǎng)絡(luò)圖片異步加載的方法,一定程度上有助于提高安卓程序的使用體驗(yàn),需要的朋友可以參考下2015-07-07