温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Mybatis中怎么利用mapper解决ID冲突问题

发布时间:2021-06-11 18:19:39 来源:亿速云 阅读:292 作者:Leah 栏目:开发技术

这篇文章给大家介绍Mybatis中怎么利用mapper解决ID冲突问题,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

mapper 的id冲突原因:

原因一:

在同一个mapper.xml中存在相同的ID

原因二:

同时使用了xml配置和注解配置

解决方案:

只保留xml或者注解即可!!!

Mybatis中怎么利用mapper解决ID冲突问题

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中怎么利用mapper解决ID冲突问题就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI