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

相关文章

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

mybatis中resultMap的association及collectio的使用详解

《mybatis中resultMap的association及collectio的使用详解》MyBatis的resultMap定义数据库结果到Java对象的映射规则,包含id、type等属性,子元素需... 目录1.reusltmap的说明2.association的使用3.collection的使用4.总

mybatis-plus QueryWrapper中or,and的使用及说明

《mybatis-plusQueryWrapper中or,and的使用及说明》使用MyBatisPlusQueryWrapper时,因同时添加角色权限固定条件和多字段模糊查询导致数据异常展示,排查发... 目录QueryWrapper中or,and使用列表中还要同时模糊查询多个字段经过排查这就导致只要whe

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

Java堆转储文件之1.6G大文件处理完整指南

《Java堆转储文件之1.6G大文件处理完整指南》堆转储文件是优化、分析内存消耗的重要工具,:本文主要介绍Java堆转储文件之1.6G大文件处理的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言文件为什么这么大?如何处理这个文件?分析文件内容(推荐)删除文件(如果不需要)查看错误来源如何避

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处