mybatis多层嵌套resultMap及返回自定义参数详解
1.两层嵌套,一个list中加另外一个list
data:[ {a:123,b:456,c:[{d:7,e:8}]} ]
xml文件定义的sql
select*fromzhyzLEFTJOINwlwonz.id=w.zid
resultMap可以定义:
如果测试表zhy与wl表中存在重复名称的字段可以使用columnPrefix
注意w_
selectz.*,w.basw_b,w.casw_cfromzhyzLEFTJOINwlwonz.id=w.zid
如果接收的实体是自定义的实体并且还有默认参数
当resultMap返回的实体中存在默认值的时候,发现外层的zhy是可以赋值成功的,但是内层的wl却没有,这个时候需要将自动生成的BaseResultMap复制一份重新定义接收实体类
/** *比如这样实体接收中存在默认赋值 * *@authorzhy */ @EqualsAndHashCode(callSuper=true) @Data publicclassWlVoextendsWl{ /** *默认赋值false */ privatebooleanselect=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
其中Map的key值为查询的属性,Object为查询的值.
注:使用map类型无法转换成驼峰命名,建议还是使用resultMap类型
以上这篇mybatis多层嵌套resultMap及返回自定义参数详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。