分页查询 分页展示
分页操作
MP| 使用 MyBatis Plus
分页操作是在MP常规操作的基础之上增强而得到的。
内部是动态SQL语句实现的,因此需要增强对应的功能,使用MP拦截器实现?????? 【why???】
- 创建springboot项目,引入MP依赖等
- 连接数据库
- 还需要MP配置类(MP拦截器 在该拦截其中添加分页拦截器)
- 使用测试类测试方法在控制台中打印输出查看效果
@Test
public void testPage() {
// 测试分页查询
// 1. 创建一个 Page 对象,传入当前页,每页记录数
// 2. 调用 BookDao 中 selectPage
IPage 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的日志显示)才能看到操作的整个过程