mybatis的resultMap中字段重名处理

2024-03-19 18:38

本文主要是介绍mybatis的resultMap中字段重名处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题

在写mybatis的关联查询时,resultMap中如果两个对象有相同的属性。查询出来的结果内层的对象的属性会被外层对象属性覆盖,导致内层list数据出错。

resultMap结构如下:

<resultMap id="DetailResultMap" type="com.tchirk.itsm.ca.domain.System"><result column="object_version_number" jdbcType="BIGINT" property="objectVersionNumber"/><result column="created_by" jdbcType="BIGINT" property="createdBy"/><result column="creation_date" jdbcType="TIMESTAMP" property="creationDate"/><collection property="moduleList" ofType="com.tchirk.itsm.ca.domain.Module"><result column="object_version_number" jdbcType="BIGINT" property="objectVersionNumber"/><result column="created_by" jdbcType="BIGINT" property="createdBy"/><result column="creation_date" jdbcType="TIMESTAMP" property="creationDate"/></collection></resultMap>

查询关联对象的SELECT语句如下

<select id="selectSystem" resultMap="DetailResultMap" resultType="com.tchirk.itsm.ca.domain.System">SELECTs1.object_version_number,s1.last_updated_by,s1.last_update_date,m1.object_version_number,m1.last_updated_by,m1.last_update_dateFROM itsm_system s1left join itsm_module m1on m1.system_id=s1.system_id
</select>

解决

将关联对象的相同属性名重命名,然后在resultMap中将column属性修改为查询语句中重命名的名字。

<select id="selectSystem" resultMap="DetailResultMap" resultType="com.tchirk.itsm.ca.domain.System">SELECTs1.object_version_number,s1.last_updated_by,s1.last_update_date,m1.object_version_number m1_object_version_number,m1.last_updated_by m1_last_updated_by,m1.last_update_date m1_last_update_dateFROM itsm_system s1left join itsm_module m1on m1.system_id=s1.system_id
</select>
    <resultMap id="DetailResultMap" type="com.tchirk.itsm.ca.domain.System"><result column="object_version_number" jdbcType="BIGINT" property="objectVersionNumber"/><result column="created_by" jdbcType="BIGINT" property="createdBy"/><result column="creation_date" jdbcType="TIMESTAMP" property="creationDate"/><collection property="moduleList" ofType="com.tchirk.itsm.ca.domain.Module"><result column="m1_object_version_number" jdbcType="BIGINT" property="objectVersionNumber"/><result column="m1_created_by" jdbcType="BIGINT" property="createdBy"/><result column="m1_creation_date" jdbcType="TIMESTAMP" property="creationDate"/></collection></resultMap>

这篇关于mybatis的resultMap中字段重名处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/826925

相关文章

MyBatis与其使用方法示例详解

《MyBatis与其使用方法示例详解》MyBatis是一个支持自定义SQL的持久层框架,通过XML文件实现SQL配置和数据映射,简化了JDBC代码的编写,本文给大家介绍MyBatis与其使用方法讲解,... 目录ORM缺优分析MyBATisMyBatis的工作流程MyBatis的基本使用环境准备MyBati

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

Gin框架中的GET和POST表单处理的实现

《Gin框架中的GET和POST表单处理的实现》Gin框架提供了简单而强大的机制来处理GET和POST表单提交的数据,通过c.Query、c.PostForm、c.Bind和c.Request.For... 目录一、GET表单处理二、POST表单处理1. 使用c.PostForm获取表单字段:2. 绑定到结

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

Python自动化处理手机验证码

《Python自动化处理手机验证码》手机验证码是一种常见的身份验证手段,广泛应用于用户注册、登录、交易确认等场景,下面我们来看看如何使用Python自动化处理手机验证码吧... 目录一、获取手机验证码1.1 通过短信接收验证码1.2 使用第三方短信接收服务1.3 使用ADB读取手机短信1.4 通过API获取

Python自动化Office文档处理全攻略

《Python自动化Office文档处理全攻略》在日常办公中,处理Word、Excel和PDF等Office文档是再常见不过的任务,手动操作这些文档不仅耗时耗力,还容易出错,幸运的是,Python提供... 目录一、自动化处理Word文档1. 安装python-docx库2. 读取Word文档内容3. 修改

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

SpringBoot+MyBatis-Flex配置ProxySQL的实现步骤

《SpringBoot+MyBatis-Flex配置ProxySQL的实现步骤》本文主要介绍了SpringBoot+MyBatis-Flex配置ProxySQL的实现步骤,文中通过示例代码介绍的非常详... 目录 目标 步骤 1:确保 ProxySQL 和 mysql 主从同步已正确配置ProxySQL 的

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec

使用C++将处理后的信号保存为PNG和TIFF格式

《使用C++将处理后的信号保存为PNG和TIFF格式》在信号处理领域,我们常常需要将处理结果以图像的形式保存下来,方便后续分析和展示,C++提供了多种库来处理图像数据,本文将介绍如何使用stb_ima... 目录1. PNG格式保存使用stb_imagephp_write库1.1 安装和包含库1.2 代码解