最近项目上遇到一个奇怪的问题,使用了mybatis分页之后,发现页面展示记录的时候,同一个人竟然会在相邻的两页里边出现,
即同一个人有两个row_id,经核查,是mybatis的版本较低导致的,如下为3.4以下版本的查询sql
SELECT *
FROM (SELECT TMP_PAGE.*, ROWNUM as ROW_ID
FROM (sql order by opendate desc) TMP_PAGE WHERE ROWNUM <= 30)
WHERE ROW_ID > 20
下边是3.4以上的查询sql
SELECT *
FROM (SELECT TMP_PAGE.*, ROWNUM ROW_ID
FROM (sql order by opendate desc) TMP_PAGE )
WHERE ROW_ID <= 30
AND ROW_ID > 20
总结分析在于老的版本进行了两次截取,新版本一次截取完成。
最终的pom文件
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>orderby-helper</artifactId>
<version>0.0.1</version>
<exclusions>
<exclusion>
<groupId>com.github.jsqlparser</groupId>
<artifactId>jsqlparser</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.2.12</version>
<exclusions>
<exclusion>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.5</version>
</dependency>