您的位置:首页技术文章
文章详情页

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

浏览:2日期:2023-10-21 08:59:27

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 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 type='zhy的doman实体' extends='zhy自动生成的BaseResultMap'> <collection property='c' resultMap='wl自动生成的BaseResultMap' columnPrefix='w_'/></resultMap>

如果接收的实体是自定义的实体并且还有默认参数

当resultMap返回的实体中存在默认值的时候,发现外层的zhy是可以赋值成功的,但是内层的wl却没有,这个时候需要将自动生成的BaseResultMap复制一份重新定义接收实体类

/** * 比如这样实体接收中存在默认赋值 * * @author zhy */@EqualsAndHashCode(callSuper = true)@Datapublic class WlVo extends Wl { /** * 默认赋值false */ private boolean select = false;}

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

<resultMap type='com.yasugongshang.db.vo.WlVo'> <id column='id' jdbcType='BIGINT' property='id' /> <result column='a' jdbcType='BIGINT' property='a' /></resultMap><resultMap 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 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 resultType='Map'> //查询语句</select>

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

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

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

标签: Mybatis 数据库
相关文章: