mybatis多層巢狀resultMap及返回自定義引數詳解
阿新 • • 發佈:2020-12-01
1.兩層巢狀,一個list中加另外一個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 id="zhyResultMap" type="zhy的doman實體" extends="zhy自動生成的BaseResultMap"> <collection property="c" resultMap="wl自動生成的BaseResultMap"/> </resultMap>
如果測試表zhy與wl表中存在重複名稱的欄位可以使用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 id="zhyResultMap" type="zhy的doman實體" extends="zhy自動生成的BaseResultMap"> <collection property="c" resultMap="wl自動生成的BaseResultMap" columnPrefix="w_"/> </resultMap>
如果接收的實體是自定義的實體並且還有預設引數
當resultMap返回的實體中存在預設值的時候,發現外層的zhy是可以賦值成功的,但是內層的wl卻沒有,這個時候需要將自動生成的BaseResultMap複製一份重新定義接收實體類
/** * 比如這樣實體接收中存在預設賦值 * * @author zhy */ @EqualsAndHashCode(callSuper = true) @Data public class WlVo extends Wl { /** * 預設賦值false */ private boolean select = false; }
將type改為自定義的之後在引用
<resultMap id="wlBaseResultMap" type="com.yasugongshang.db.vo.WlVo"> <id column="id" jdbcType="BIGINT" property="id" /> <result column="a" jdbcType="BIGINT" property="a" /> </resultMap> <resultMap id="zhyResultMap" type="zhy的doman實體" extends="zhy自動生成的BaseResultMap"> <collection property="c" resultMap="wlBaseResultMap" columnPrefix="w_"/> </resultMap>
2.三層巢狀,一個list中加另外一個list,內list中還存在list
data:[ {a:123,e:8,f:[str]}]} ]
這時候只需要在內層wlBaseResultMap中再增加一個collection即可
需要注意的是這個時候columnPrefix可能會導致資料為空
<resultMap id="wlBaseResultMap" 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>
補充知識:Mybatis中查詢返回多個物件使用resultType使用Map型別代替resultMap
查詢resultType直接使用Type,Dao層返回物件為List巢狀的一個Map資料結構
List<Map<String,Object>> selectAll(); <select id="selectAll" resultType="Map"> //查詢語句 </select>
其中Map的key值為查詢的屬性,Object為查詢的值.
注:使用map型別無法轉換成駝峰命名,建議還是使用resultMap型別
以上這篇mybatis多層巢狀resultMap及返回自定義引數詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。