栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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


 

如果测试表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复制一份重新定义接收实体类


@EqualsAndHashCode(callSuper = true)
@Data
public class WlVo extends Wl {
 
 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及返回自定义参数详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/130171.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号