解决Mybatis中mapper的ID冲突问题

 更新时间:2021年06月11日 15:24:26   作者:瑰  
这篇文章主要介绍了解决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的话,则每次查询查出来的列可以不相同,这样才能应对不同的表结构。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • spring-boot-maven-plugin引入出现爆红(已解决)

    spring-boot-maven-plugin引入出现爆红(已解决)

    这篇文章主要介绍了spring-boot-maven-plugin引入出现爆红(已解决),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • 一文学透ApplicationContext继承接口功能及与BeanFactory区别

    一文学透ApplicationContext继承接口功能及与BeanFactory区别

    这篇文章主要为大家介绍了ApplicationContext继承接口功能及与BeanFactory区别示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • SpringBoot2.x的依赖管理配置

    SpringBoot2.x的依赖管理配置

    这篇文章主要介绍了SpringBoot2.x的依赖管理配置,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • Java生成图形验证码工具类

    Java生成图形验证码工具类

    这篇文章主要介绍了Java生成图形验证码工具类,本文思路明确介绍的非常详细,需要的朋友可以参考下
    2017-02-02
  • Java手写持久层框架的详细代码

    Java手写持久层框架的详细代码

    这篇文章主要介绍了Java手写持久层框架,本文适合有一定java基础的同学,通过自定义持久层框架,可以更加清楚常用的mybatis等开源框架的原理,需要的朋友可以参考下
    2022-08-08
  • Java 实现倒计时功能(由秒计算天、小时、分钟、秒)

    Java 实现倒计时功能(由秒计算天、小时、分钟、秒)

    最近做项目遇到这样的需求,天、小时、分钟、秒的数值都是隔开的,服务器端只返回一个时间戳长度,怎么实现这样的功能呢?下面小编给大家带来了Java 实现倒计时功能的方案,需要的朋友参考下吧
    2018-01-01
  • SpringBoot2如何集成Elasticsearch6.x(TransportClient方式)

    SpringBoot2如何集成Elasticsearch6.x(TransportClient方式)

    这篇文章主要介绍了SpringBoot2如何集成Elasticsearch6.x(TransportClient方式)问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • Java实现树形List与扁平List互转的示例代码

    Java实现树形List与扁平List互转的示例代码

    在平时的开发中,我们时常会遇到需要将"树形List"与"扁平List"互转的情况,本文为大家整理了Java实现树形List与扁平List互转的示例代码,希望对大家有所帮助
    2023-05-05
  • javaWeb实现简单文件上传

    javaWeb实现简单文件上传

    这篇文章主要为大家详细介绍了JAVAWeb实现简单文件上传,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • idea项目的左侧目录没了如何设置

    idea项目的左侧目录没了如何设置

    这篇文章主要介绍了idea项目的左侧目录没了如何设置的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02

最新评论