mybatis使用resultMap定義多層嵌套關係:
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,b:456,c:[{d:7,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>