PageHelper是一种分页插件,下面介绍在实际业务的不同情况下使用需要注意的地方。
1. 依赖导入
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.4</version>
</dependency>
2. 分页插件的使用
2.1 对查询语句的结果进行分页
一般情况下是使用PageHelper插件对查询语句的结果进行分页,具体实现如下:
PageHelper.startPage(pageNum, pageSize);
Page<TestDemo> testDemoPageData = (Page<TestDemo>) testDemoMapper.selectByExample(testDemoExample);
List<TestDemo> testDemoResults = testDemoPageData.getResult();
2.2 对已存在的列表进行分页
然而,实际业务中可能需要对多表查询的结果进行聚合,然后存储到List集合中,这种情况下则需要进行手动分页。
// 已有的List集合:List<TestDemo> profiles
Page<TestDemo> page = new Page<>(pageNum, pageSize);
page.setTotal(profiles.size());
int startIndex = (pageNum - 1) * pageSize;
int endIndex = Math.min(startIndex + pageSize, profiles.size());
page.addAll(profiles.subList(startIndex, endIndex));
List<TestDemo> testDemoResults = page.getResult();
3. 总结
在实际业务中使用PageHelper分页插件要根据具体需求具体使用。