Springboot整合PageHelper,分页不起作用
- 依赖
首先看引入的以来是否正确:
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.3.0</version>
</dependency>
并不是下面这个单独的pagehelper:
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.2</version>
</dependency>
鄙人不幸在此踩坑:找了好久最后发现是依赖问题:
- 配置
这个有两种方式,一种是在配置文件里写,一种是写配置类:
@Configuration
public class PageHelperConfig {
@Bean
public PageHelper pageHelper() {
PageHelper pageHelper = new PageHelper();
Properties p = new Properties();
p.setProperty("dialect", "Mysql");
p.setProperty("offsetAsPageNum", "true");
p.setProperty("rowBoundsWithCount", "true");
pageHelper.setProperties(p);
return pageHelper;
}
}
或者:
#pagehelper分页插件配置
pagehelper:
helperDialect: mysql
reasonable: true
supportMethodsArguments: true
params: count=countSql
- 分页代码
public PageInfo selectByKey(int page, int size, String userName) {
PageHelper.startPage(page,size);
List<User> userList = userMapper.selectByKey(userName);
PageInfo<User> pageInfo = new PageInfo<User>(userList);
return pageInfo;
}
类似于上面这种(这个是service层的Impl里的);
注意的是:首先必须要写
PageHelper.startPage(page,size);
然后要紧跟着被分页的数据的查询代码;该分页插件底层为保障安全性,因此分页只会对紧跟在其后的查询的结果有效;我在网上搜到好多都是这种的。
最后:
PageInfo pageInfo = new PageInfo(userList);
然后就可以实现分页功能了;基本就没啥问题了。