MyBatis ResultMap去重操作,怎样操作

导读 有时候用MyBatis查询结果集,将打印的sql语句放在数据库客户端执行,比如结果为10条,但是MyBatis返回的数据却只有4条,这是为什么呢?

MyBatis的ResultMap默认是把id作为map的主键,当id相同时,不管其他字段相不相同,它都当作相同的记录。那当我们想要MyBatis不去重,怎么操作呢?在POJO定义中加入一个伪id作为一标识即可。如:

在主表类(User.java)里 添加一个“伪列”,作用:不去重

MyBatis ResultMap去重操作,怎样操作MyBatis ResultMap去重操作,怎样操作

UserMapper.xml

MyBatis ResultMap去重操作,怎样操作MyBatis ResultMap去重操作,怎样操作

运行结果

MyBatis ResultMap去重操作,怎样操作MyBatis ResultMap去重操作,怎样操作原理:该sql语句生成一列不重复的数据,例如:行号;以该列作为主键,MyBatis检测主键不重复,所以返回多条数据记录。

原文来自:https://my.oschina.net/liuh1988/blog/1541711

本文地址: http://www.linuxprobe.com/mybatis-resultmap.html

 

 

posted @ 2017-09-27 23:55  顾少侠  阅读(357)  评论(0编辑  收藏  举报