Mybatis自动去重,以及id vs result_mybatis去重-程序员宅基地

技术标签: # mybatis  mybatis  数据库  

今天大部分时间一直被一个问题困扰:当程序执行某Mapper.java的一个list函数,明明底层的SQL语句和ELK中的日志都显示返回了376条记录(如图1,图2),最后程序却只返回了209条。
zz
图1: 日志显示此list函数返回了376条记录

{conn-10056, pstmt-34049, rs-52649} Result
图2: 日志有376条相关的ResultSet记录

我一度以为这跟今天尝试使用的MyBatis分页插件PageHelper(使用了MySql的limit)有关,后面发现不是。即使不使用PageHelper,问题依旧。而且我发现一点:实际返回的209条记录里,似乎ID没有重复的。后面我一搜,也经过实验验证了一点:MyBatis会自动去重。更具体来说,MyBatis会根据resultmap中的<id>标签自动去重。

那么应该如何防止MyBatis自动去重呢?
方法一:可以增加伪列1(尚未亲自验证)
方法二:在<resultMap>中使用多个ID列2,3(尚未亲自验证,但是推荐,相当于起到了复合主键的作用)

附:一些相关资料:

id & result 4

The only difference between the two is that id will flag the result as an identifier property to be used when comparing object instances.

简书:MyBatis <resultMap>中的<id>的作用到底是什么?


  1. mybatis 自动去重问题及解决

  2. mybatis的映射会根据id自动去重

  3. Composite Keys in Resultmaps

  4. https://mybatis.org/mybatis-3/sqlmap-xml.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_23204557/article/details/120092094

智能推荐

每日一道python题(python数据结构课后习题(第一章1-4题))_一个雇员一周的总薪水,等于其每个小时的时薪,乘以其一周工作的正常小时数,再-程序员宅基地

文章浏览阅读5.1k次,点赞2次,收藏11次。python入门级小白,仅用来自我学习的,写的不恰当的地方请多指教。(python3.)1.编写一个程序,以球体的半径(浮点型)作为输入,并并且输出球体的直径,圆周长和表面积import mathr = float(input('请输入球体半径r:'))d = 2*rc= 4*math.pi*r**2v = 4/3*math.pi*r**3print("球体直径为%f\n球体表面积为%f\n球体体..._一个雇员一周的总薪水,等于其每个小时的时薪,乘以其一周工作的正常小时数,再

RabbitMQ输出日志配置_rabbitmq日志配置-程序员宅基地

文章浏览阅读1.7k次。参考地址。_rabbitmq日志配置

利用Tableau绘制各类图表_tableau图表-程序员宅基地

文章浏览阅读3.4k次,点赞5次,收藏42次。这是可视化Tableau部分汇总的一篇文章,细分可看细分单元。_tableau图表

penuppendown在python中是啥意思_Python turtle.pendown方法代碼示例-程序员宅基地

文章浏览阅读2.9k次。本文整理匯總了Python中turtle.pendown方法的典型用法代碼示例。如果您正苦於以下問題:Python turtle.pendown方法的具體用法?Python turtle.pendown怎麽用?Python turtle.pendown使用的例子?那麽恭喜您, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在模塊turtle的用法示例。在下文中一共展示了tu..._pendown在python是什么意思

adb帮助文档_adb中文文档-程序员宅基地

文章浏览阅读3.7k次。adb帮助文档_adb中文文档

解决qt_creator: this file is not part of any project问题-程序员宅基地

文章浏览阅读8.1k次,点赞2次,收藏2次。解决qt_creator: this file is not part of any project问题利用qt_creator导入已经生成好的ros workspace后,在此src下面添加文件会出现warning:this file is not part of any project 同时,代码在编写的时候会有报错,虽然编译可以正常通过并且代码能够正常运行,但是无法使用qt的代码补全功能。ROS_WIKI给出了这样的解释但是没有给出详细的解决方案,根据本人测试结果,通过重新构建整个项目,即可解_this file is not part of any project

随便推点

uni-app开发h5,打开h5自动播放视频_uniapp h5自动播放视频-程序员宅基地

文章浏览阅读3.3k次。使用标签,加上autoplay属性并没有用出于用户体验,节省流量的考虑,移动端禁止自动播放;使用过模拟用户点击操作,等等方法,并没有用。参考https://www.mzwu.com/article.asp?id=4411优酷页面打开后视频不自动播放,需用户点击按钮才开始播放,B站解决方法和优酷一样,爱奇艺页面打开后视频自动开始播放,但声音需用户手工开启,所以暂时不要去想什么hack的方法了,有办法这些大厂早用了,还是老老实实引导用户手工点一下吧。所以,加上静音播放属性muted,就可以打开h5自_uniapp h5自动播放视频

Android Studio中的Android项目调用第三方库so库_android 引用第三方库中的类-程序员宅基地

文章浏览阅读1k次。Android NDK开发中,除了可以通过自己编写C/C++代码来构建动态连接库进行调用之外,还可以通过直接调用现成的so库开进行NDK开发。接下来,我将介绍在Android Studio中如何调用第三方动态连接库。 首先需要考虑的是如何获得so库文件,这里介绍自己编译生成的方法。 在该项目的基础上http://blog.csdn.net/sinat_19385391/a_android 引用第三方库中的类

jvm堆中对象存活算法,内存泄漏,垃圾回收算法_垃圾回收算法,内存泄漏场景-程序员宅基地

文章浏览阅读235次。首先说面:下面所有内容都是针对jvm 中堆区域。堆里面对象的回收jvm自动帮我们实现的,但是我们也需要了解其原理。jvm堆中对象存活算法及其优缺点1 引用计数算法给对象增加引用计数器,每当有一个地方引用它时,计数器值加1;引用失效时,计数器值减1。当计数器的值为0时,代表可以回收了。但是很难解决对象之间的相互循环引用.2 可达性分析算法以一些称为”GC ROOTS”的节点作为起点,从..._垃圾回收算法,内存泄漏场景

网线选购-程序员宅基地

文章浏览阅读98次。如果将网卡比作是车,将交换机比作为立交桥,那么,网线就是路。可以想见,即使拥有高级跑车和现代化的立交桥,如果路况差得一塌胡涂,那么,整体速度也快不到哪儿去!另外,“路”一旦铺就,若欲推掉重来其困难程度可想而知。由此可见,网线的选购在网络建设就显得非常重要。就目前来看,主要可供选择的双绞线大致有两类,即超五类和六类。一、超五类与六类非屏蔽双绞线曾经辉煌..._2. 若网线老旧或网线内部损坏,建议更换新的高规格网线(超玉类网线

httos双向认证配置_NGINX 配置本地HTTPS(双向认证)-程序员宅基地

文章浏览阅读1.8k次。一、SSL协议加密方式SSL协议即用到了对称加密也用到了非对称加密(公钥加密),在建立传输链路时,SSL首先对对称加密的密钥使用公钥进行非对称加密,链路建立好之后,SSL对传输内容使用对称加密。1.对称加密速度高,可加密内容较大,用来加密会话过程中的消息。2.公钥加密加密速度较慢,但能提供更好的身份认证技术,用来加密对称加密的密钥。单向认证Https在建立Socket连接之前,需要进行握手,具体过..._httos″81278 ″osh

通过Zadig给蓝牙适配器安装驱动后,无法恢复的解决办法_csr8510 a10蓝牙驱动-程序员宅基地

文章浏览阅读3.2k次,点赞2次,收藏4次。通过Zadig给蓝牙适配器安装驱动后,无法恢复的解决办法问题描述蓝牙适配器型号是CSR 8510 A10, 在WIN10里可识别为蓝牙适配器。用Zadig给蓝牙适配器安装WinUSB驱动后,蓝牙适配器无法被Win10正常识别,回退驱动是灰色,删除卸载设备和驱动、重启电脑都没有用。解决办法进入设备管理器找到通用串行总线设备里的CSR8510 A10(如果不在这里你就一个个找csr开头的设备,然后通过蓝牙适配器的插拔,定位到是不是你选的驱动)右击选择更新驱动程序选择浏览我的计_csr8510 a10蓝牙驱动

推荐文章

热门文章

相关标签