Mybatis-Plus分页插件

时间:2025-04-27 08:42:07

引言:

MyBatis Plus自带分页插件,只要简单的配置即可实现分页功能

1.添加Configuration配置类

@Configuration
@MapperScan("") //可以将主类中的注解移到此处
    public class MybatisPlusConfig {
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
    MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
    (new
    PaginationInnerInterceptor());
    return interceptor;
    }
}

2.测试

@Test
public void testPage(){
        //设置分页参数,泛型<User>查询此类
        Page<User> page = new Page<>(1, 5);//第一参数为当前页,第二个参数为页包含多少数据
        (page, null);
        //获取分页数据
        List<User> list = ();
        (::println);
        //输出对应真个的信息
        ("当前页:"+());
        ("每页显示的条数:"+());
        ("总记录数:"+());
        ("总页数:"+());
        ("是否有上一页:"+());
        ("是否有下一页:"+());
}

3.自定义xml分页

mapper接口中的方法

Page<User> selectPageVo(@Param("page") Page<User> page, @Param("age")
Integer age);//结构必须保持一致

mapper的xml文件

<sql >id,username,age,email</sql>
<!--IPage<User> selectPageVo(Page<User> page, Integer age);-->
<select  resultType="User">
SELECT <include ref></include> FROM t_user WHERE age > #
{age}
</select

测试

@Test
public void testSelectPageVo(){
//设置分页参数
    Page<User> page = new Page<>(1, 5);
    (page, 20);
    //获取分页数据
    List<User> list = ();
    (::println);
    ("当前页:"+());
    ("每页显示的条数:"+());
    ("总记录数:"+());
    ("总页数:"+());
    ("是否有上一页:"+());
    ("是否有下一页:"+());
}

结果

User(id=3, name=Tom, age=28, email= test3@, isDeleted=null) User(id=4, name=Sandy, age=21, email= test4@, isDeleted=null) User(id=5, name=Billie, age=24, email= test5@, 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分页插件在企业开发应用更多