MyBatis Plus自带分页插件,只要简单的配置即可实现分页功能
@Configuration
@MapperScan("com.atguigu.mybatisplus.mapper") //可以将主类中的注解移到此处public class MybatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(newPaginationInnerInterceptor(DbType.MYSQL));return interceptor;}
}
@Test
public void testPage(){//设置分页参数,泛型查询此类Page page = new Page<>(1, 5);//第一参数为当前页,第二个参数为页包含多少数据userMapper.selectPage(page, null);//获取分页数据List list = page.getRecords();list.forEach(System.out::println);//输出对应真个的信息System.out.println("当前页:"+page.getCurrent());System.out.println("每页显示的条数:"+page.getSize());System.out.println("总记录数:"+page.getTotal());System.out.println("总页数:"+page.getPages());System.out.println("是否有上一页:"+page.hasPrevious());System.out.println("是否有下一页:"+page.hasNext());
}
Page selectPageVo(@Param("page") Page page, @Param("age")
Integer age);//结构必须保持一致
id,username,age,email
@Test
public void testSelectPageVo(){
//设置分页参数Page page = new Page<>(1, 5);userMapper.selectPageVo(page, 20);//获取分页数据List list = page.getRecords();list.forEach(System.out::println);System.out.println("当前页:"+page.getCurrent());System.out.println("每页显示的条数:"+page.getSize());System.out.println("总记录数:"+page.getTotal());System.out.println("总页数:"+page.getPages());System.out.println("是否有上一页:"+page.hasPrevious());System.out.println("是否有下一页:"+page.hasNext());
}
User(id=3, name=Tom, age=28, email=test3@baomidou.com, isDeleted=null) User(id=4, name=Sandy, age=21, email=test4@baomidou.com, isDeleted=null) User(id=5, name=Billie, age=24, email=test5@baomidou.com, isDeleted=null) User(id=8, name=ybc1, age=21, email=null, isDeleted=null) User(id=9, name=ybc2, age=22, email=null, isDeleted=null) 当前 页:1 每页显示的条数:5 总记录数:12 总页数:3 是否有上一页:false 是否有下一页:true
整体遵循约定大于配置
按照给定的结构编写,不会报错,否则无法实现相关功能
Mybatis-Plus分页插件大大降低的开发难度
Mybatis-Plus分页插件在企业开发应用更多
下一篇:优化设计流程的“闭环”问题