mybatis多層嵌套resultMap及返回自定義參數(shù)詳解
1.兩層嵌套,一個(gè)list中加另外一個(gè)list
data:[{a:123,b:456,c:[{d:7,e:8}]}]
xml文件定義的sql
select * from zhy z LEFT JOIN wl w on z.id = w.zid
resultMap可以定義:
<resultMap type='zhy的doman實(shí)體' extends='zhy自動(dòng)生成的BaseResultMap'> <collection property='c' resultMap='wl自動(dòng)生成的BaseResultMap'/></resultMap>
如果測(cè)試表zhy與wl表中存在重復(fù)名稱的字段可以使用columnPrefix
注意w_
select z.*,w.b as w_b,w.c as w_c from zhy z LEFT JOIN wl w on z.id = w.zid
<resultMap type='zhy的doman實(shí)體' extends='zhy自動(dòng)生成的BaseResultMap'> <collection property='c' resultMap='wl自動(dòng)生成的BaseResultMap' columnPrefix='w_'/></resultMap>
如果接收的實(shí)體是自定義的實(shí)體并且還有默認(rèn)參數(shù)
當(dāng)resultMap返回的實(shí)體中存在默認(rèn)值的時(shí)候,發(fā)現(xiàn)外層的zhy是可以賦值成功的,但是內(nèi)層的wl卻沒(méi)有,這個(gè)時(shí)候需要將自動(dòng)生成的BaseResultMap復(fù)制一份重新定義接收實(shí)體類(lèi)
/** * 比如這樣實(shí)體接收中存在默認(rèn)賦值 * * @author zhy */@EqualsAndHashCode(callSuper = true)@Datapublic class WlVo extends Wl { /** * 默認(rèn)賦值false */ private boolean select = false;}
將type改為自定義的之后在引用
<resultMap type='com.yasugongshang.db.vo.WlVo'> <id column='id' jdbcType='BIGINT' property='id' /> <result column='a' jdbcType='BIGINT' property='a' /></resultMap><resultMap type='zhy的doman實(shí)體' extends='zhy自動(dòng)生成的BaseResultMap'> <collection property='c' resultMap='wlBaseResultMap' columnPrefix='w_'/></resultMap>
2.三層嵌套,一個(gè)list中加另外一個(gè)list,內(nèi)list中還存在list
data:[{a:123,b:456,c:[{d:7,e:8,f:[str]}]}]
這時(shí)候只需要在內(nèi)層wlBaseResultMap中再增加一個(gè)collection即可
需要注意的是這個(gè)時(shí)候columnPrefix可能會(huì)導(dǎo)致數(shù)據(jù)為空
<resultMap type='com.yasugongshang.db.vo.WlVo'> <id column='id' jdbcType='BIGINT' property='id' /> <result column='a' jdbcType='BIGINT' property='a' /> <collection property='f' ofType='string'> <id column='f' jdbcType='VARCHAR'/> </collection></resultMap>
補(bǔ)充知識(shí):Mybatis中查詢返回多個(gè)對(duì)象使用resultType使用Map類(lèi)型代替resultMap
查詢r(jià)esultType直接使用Type,Dao層返回對(duì)象為L(zhǎng)ist嵌套的一個(gè)Map數(shù)據(jù)結(jié)構(gòu)
List<Map<String,Object>> selectAll();<select resultType='Map'> //查詢語(yǔ)句</select>
其中Map的key值為查詢的屬性,Object為查詢的值.
注:使用map類(lèi)型無(wú)法轉(zhuǎn)換成駝峰命名,建議還是使用resultMap類(lèi)型
以上這篇mybatis多層嵌套resultMap及返回自定義參數(shù)詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. MySQL 字符串函數(shù):字符串截取2. IBM DB2通用數(shù)據(jù)庫(kù)和信息管理(1)3. Linux安裝ODBC連接SQLServer數(shù)據(jù)庫(kù)的步驟4. Mysql根據(jù)某層部門(mén)ID查詢所有下級(jí)多層子部門(mén)的示例5. Oracle學(xué)習(xí)筆記之二----查詢6. MSSQL2005的新功能創(chuàng)建數(shù)據(jù)庫(kù)快照7. DB2高可用性災(zāi)難恢復(fù)(HADR)的限制8. Microsoft Office Access調(diào)整字段位置的方法9. MySQL之mysqldump的使用詳解10. navicat for mysql導(dǎo)出sql文件的方法
