解决方案:
手动写查询语句。
官方链接:https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/Changelog.md#504---2017-08-01
增加手写 count 查询支持
增加 countSuffix
count 查询后缀配置参数,该参数是针对 PageInterceptor
配置的,默认值为 _COUNT
。
分页插件会优先通过当前查询的 msId + countSuffix
查找手写的分页查询。
如果存在就使用手写的 count 查询,如果不存在,仍然使用之前的方式自动创建 count 查询。
例如,如果存在下面两个查询:
<select id="selectLeftjoin" resultType="com.github.pagehelper.model.User"> select a.id,b.name,a.py from user a left join user b on a.id = b.id order by a.id </select> <select id="selectLeftjoin_COUNT" resultType="Long"> select count(distinct a.id) from user a left join user b on a.id = b.id </select>
上面的 countSuffix
使用的默认值 _COUNT
,分页插件会自动获取到 selectLeftjoin_COUNT
查询,这个查询需要自己保证结果数正确。
返回值的类型必须是resultType="Long"
,入参使用的和 selectLeftjoin
查询相同的参数,所以在 SQL 中要按照 selectLeftjoin
的入参来使用。
注意注意: PageHelper需要5.0.4版以后。
如果你用的是,SpringBoot集成的这种jar包。
<dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>1.2.13</version> </dependency>
看下面,版本号下面都有对应的PageHelper的版本,选大于5.0的版本。