欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

mybatis多层嵌套resultMap及返回自定义参数详解

时间:2021-05-08 09:07:23|栏目:JAVA代码|点击:

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>

补充知识: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类型

上一篇:Java用户登录验证代码

栏    目:JAVA代码

下一篇:Java中避免写嵌套if样式的代码详解

本文标题:mybatis多层嵌套resultMap及返回自定义参数详解

本文地址:http://www.codeinn.net/misctech/117304.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有