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

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐