解决Mybatis中mapper的ID冲突问题
mapper 的id冲突原因:
原因一:
在同一个mapper.xml中存在相同的ID
原因二:
同时使用了xml配置和注解配置
解决方案:
只保留xml或者注解即可!!!
Mybatis mapper文件下同一id 查询结果列不同问题
场景描述:
订单数据按天分表,正常情况下每一天的表结构都是一样的,表名命名格式order_yyyyMMdd。
定义一个查询如下:
<select id="orderSelect" parameterClass="java.util.HashMap" resultClass="com.xxx"> select * from order_$table_suffix$ where ... </select>
如果我查询18年10月1日数据,则传参数table_suffix=20181001,如果我查询18年10月2日数据,则传参数table_suffix=20181002.即可。
系统运行了若干天,到了18年12月30日,order表添加了新的字段a。以后的订单表都会添加该字段。对应的实体类也添加了对应字段。应该没有问题了,更新并重启程序。先查询今天的数据,没有问题。在查询之前的数据,发现程序报错了,找不到字段a.
解决方法:
修改id 为orderSelect 的查询
<select id="orderSelect" remapResults="true" parameterClass="java.util.HashMap" resultClass="com.xxx"> select * from order_$table_suffix$ where ... </select>
对比发现添加了 remapResults="true"的配置
总结 :
mybatis 默认remapResults属性为false,会导致同一查询id 查出来的字段一直都是固定的。设置为true的话,则每次查询查出来的列可以不相同,这样才能应对不同的表结构。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
ImportBeanDefinitionRegistrar手动控制BeanDefinition创建注册详解
这篇文章主要为大家介绍了ImportBeanDefinitionRegistrar手动控制BeanDefinition创建注册详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-12-12SpringCloud如何使用Eureka实现服务之间的传递数据
这篇文章主要介绍了SpringCloud使用Eureka实现服务之间的传递数据操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-06-06Spring中@ConfigurationProperties的用法解析
这篇文章主要介绍了Spring中@ConfigurationProperties的用法解析,传统的Spring一般都是基本xml配置的,后来spring3.0新增了许多java config的注解,特别是spring boot,基本都是清一色的java config,需要的朋友可以参考下2023-11-11
最新评论