【SpringBoot】MyBatisPlus(MP | 分页查询操作
分页查询 分页展示
分页操作
MP| 使用 MyBatis Plus
分页操作是在MP常规操作的基础之上增强而得到的。
内部是动态SQL语句实现的,因此需要增强对应的功能,使用MP拦截器实现?????? 【why???】
- 创建springboot项目,引入MP依赖等
- 连接数据库
- 还需要MP配置类(MP拦截器 在该拦截其中添加分页拦截器)
- 使用测试类测试方法在控制台中打印输出查看效果
@Testpublic void testPage() {// 测试分页查询// 1. 创建一个 Page 对象,传入当前页,每页记录数// 2. 调用 BookDao 中 selectPageIPage page = new Page(1, 1);bookDao.selectPage(page, null);// 3. 获取分页查询结果// current 获取当前页数/当前页码System.out.println(page.getCurrent());// pages 获取总页数System.out.println(page.getPages());// size 获取每页大小/条数 获取每页显示条数System.out.println(page.getSize());// total 获取总记录数System.out.println(page.getTotal());// records 获取当前页数据 ? [Book{id=1, type='kao', name='kao', description='test'}]System.out.println(page.getRecords());
// System.out.println(page.hasPrevious());
// System.out.println(page.hasNext());
//}
- 使用MP中提供的方法
// 3. 获取分页查询结果// current 获取当前页数/当前页码System.out.println(page.getCurrent());// pages 获取总页数System.out.println(page.getPages());// size 获取每页大小/条数 获取每页显示条数System.out.println(page.getSize());// total 获取总记录数System.out.println(page.getTotal());// records 获取当前页数据 ? [Book{id=1, type='kao', name='kao', description='test'}]System.out.println(page.getRecords());
Attention
需要注意的是
- IPage封装分页数据
- 分页操作依赖于MP的拦截器实现该功能
- 我们还是需要借助MP的日志查询来执行语句 (配置MP的日志显示)才能看到操作的整个过程