mybatis 显示自定义多个统计_mybatis多层嵌套resultMap及返回自定义参数详解

本文详细介绍了如何在MyBatis中处理多层嵌套ResultMap的情况,包括两层和三层嵌套的示例。在处理过程中,强调了在存在默认值的实体类中如何正确赋值,并提到了使用columnPrefix避免字段冲突。同时,文章还提及了在某些情况下使用resultType为Map类型的缺点,并建议使用resultMap以获得更好的对象映射体验。
摘要由CSDN通过智能技术生成

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可以定义:

如果测试表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返回的实体中存在默认值的时候,发现外层的zhy是可以赋值成功的,但是内层的wl却没有,这个时候需要将自动生成的BaseResultMap复制一份重新定义接收实体类

/**

* 比如这样实体接收中存在默认赋值

*

* @author zhy

*/

@EqualsAndHashCode(callSuper = true)

@Data

public class WlVo extends Wl {

/**

* 默认赋值false

*/

private boolean select = false;

}

将type改为自定义的之后在引用

2.三层嵌套,一个list中加另外一个list,内list中还存在list

data:[

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

]

这时候只需要在内层wlBaseResultMap中再增加一个collection即可

需要注意的是这个时候columnPrefix可能会导致数据为空

补充知识:Mybatis中查询返回多个对象使用resultType使用Map类型代替resultMap

查询resultType直接使用Type,Dao层返回对象为List嵌套的一个Map数据结构

List> selectAll();

//查询语句

其中Map的key值为查询的属性,Object为查询的值.

注:使用map类型无法转换成驼峰命名,建议还是使用resultMap类型

以上这篇mybatis多层嵌套resultMap及返回自定义参数详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值