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>
补充知识: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代码
本文标题:mybatis多层嵌套resultMap及返回自定义参数详解
本文地址:http://www.codeinn.net/misctech/117304.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




