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

mybatis多層嵌套resultMap及返回自定義參數詳解

瀏覽:39日期:2023-10-21 08:59:27

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 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 type='zhy的doman實體' extends='zhy自動生成的BaseResultMap'> <collection property='c' resultMap='wl自動生成的BaseResultMap' columnPrefix='w_'/></resultMap>

如果接收的實體是自定義的實體并且還有默認參數

當resultMap返回的實體中存在默認值的時候,發現外層的zhy是可以賦值成功的,但是內層的wl卻沒有,這個時候需要將自動生成的BaseResultMap復制一份重新定義接收實體類

/** * 比如這樣實體接收中存在默認賦值 * * @author zhy */@EqualsAndHashCode(callSuper = true)@Datapublic class WlVo extends Wl { /** * 默認賦值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實體' extends='zhy自動生成的BaseResultMap'> <collection property='c' resultMap='wlBaseResultMap' columnPrefix='w_'/></resultMap>

2.三層嵌套,一個list中加另外一個list,內list中還存在list

data:[{a:123,b:456,c:[{d:7,e:8,f:[str]}]}]

這時候只需要在內層wlBaseResultMap中再增加一個collection即可

需要注意的是這個時候columnPrefix可能會導致數據為空

<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>

補充知識:Mybatis中查詢返回多個對象使用resultType使用Map類型代替resultMap

查詢resultType直接使用Type,Dao層返回對象為List嵌套的一個Map數據結構

List<Map<String,Object>> selectAll();<select resultType='Map'> //查詢語句</select>

其中Map的key值為查詢的屬性,Object為查詢的值.

注:使用map類型無法轉換成駝峰命名,建議還是使用resultMap類型

以上這篇mybatis多層嵌套resultMap及返回自定義參數詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Mybatis 數據庫
相關文章:
国产综合久久一区二区三区