时间:2021-05-19
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)@Datapublic 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类型
以上这篇mybatis多层嵌套resultMap及返回自定义参数详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
日常开发,我们可能会为了安全问题,保证第三方无法通过伪造返回报文欺骗前端,需要在返回报文中添加自定义参数,用于验证身份,后端添加自定义参数,前端校验自定义参数通
Java中自定义异常详解及实例代码下面做了归纳总结,欢迎批评指正自定义异常classChushulingExceptionextendsException{pu
AndroidViewPagerIndicator详解及实例代码关于自定义View的属性零碎知识自定义View和自定义属性的知识不再此提及,这里着重说的是属性在
前言:前面几篇讲了自定义控件绘制原理Android自定义控件基本原理详解(一),Android自定义控件之自定义属性(二),Android自定义控件之自定义组合
MyBatis简介MyBatis是一个可以自定义SQL、存储过程和高级映射的持久层框架。MyBatis摒除了大部分的JDBC代码、手工设置参数和结果集重获。My