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的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

Thymeleaf:生成静态文件及异常处理java.lang.NoClassDefFoundError: ognl/PropertyAccessor

我们需要引入包: <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>sp

Spring+MyBatis+jeasyui 功能树列表

java代码@EnablePaging@RequestMapping(value = "/queryFunctionList.html")@ResponseBodypublic Map<String, Object> queryFunctionList() {String parentId = "";List<FunctionDisplay> tables = query(parent

Mybatis中的like查询

<if test="templateName != null and templateName != ''">AND template_name LIKE CONCAT('%',#{templateName,jdbcType=VARCHAR},'%')</if>

JavaWeb【day09】--(Mybatis)

1. Mybatis基础操作 学习完mybatis入门后,我们继续学习mybatis基础操作。 1.1 需求 需求说明: 根据资料中提供的《tlias智能学习辅助系统》页面原型及需求,完成员工管理的需求开发。 通过分析以上的页面原型和需求,我们确定了功能列表: 查询 根据主键ID查询 条件查询 新增 更新 删除 根据主键ID删除 根据主键ID批量删除

MyBatis 切换不同的类型数据库方案

下属案例例当前结合SpringBoot 配置进行讲解。 背景: 实现一个工程里面在部署阶段支持切换不同类型数据库支持。 方案一 数据源配置 关键代码(是什么数据库,该怎么配就怎么配) spring:datasource:name: test# 使用druid数据源type: com.alibaba.druid.pool.DruidDataSource# @需要修改 数据库连接及驱动u

jenkins 插件执行shell命令时,提示“Command not found”处理方法

首先提示找不到“Command not found,可能我们第一反应是查看目标机器是否已支持该命令,不过如果相信能找到这里来的朋友估计遇到的跟我一样,其实目标机器是没有问题的通过一些远程工具执行shell命令是可以执行。奇怪的就是通过jenkinsSSH插件无法执行,经一番折腾各种搜索发现是jenkins没有加载/etc/profile导致。 【解决办法】: 需要在jenkins调用shell脚

明明的随机数处理问题分析与解决方案

明明的随机数处理问题分析与解决方案 引言问题描述解决方案数据结构设计具体步骤伪代码C语言实现详细解释读取输入去重操作排序操作输出结果复杂度分析 引言 明明生成了N个1到500之间的随机整数,我们需要对这些整数进行处理,删去重复的数字,然后进行排序并输出结果。本文将详细讲解如何通过算法、数据结构以及C语言来解决这个问题。我们将会使用数组和哈希表来实现去重操作,再利用排序算法对结果