详解MyBatis Plus中分页插件的使用

 更新时间:2023年02月09日 14:33:30   作者:世界尽头与你  
这篇文章主要为大家详细介绍了MyBatis Plus中分页插件使用的相关知识,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的小伙伴可以了解一下

MyBatis Plus分页插件使用

MyBatis Plus中使用分页插件也很简单:

首先编写配置类:

@Configuration
public class MyBatisPlusConfig {
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        // 构造拦截器
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        // 添加分页插件
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }
}

大功告成!现在来测试一下吧:

@Test
void contextLoads() {
    Page<User> page = new Page<>(1, 2);
    userMapper.selectPage(page, null);
    System.out.println(page);
}

==>  Preparing: SELECT COUNT(*) AS total FROM user WHERE is_delete = 0
==> Parameters: 
<==    Columns: total
<==        Row: 3
<==      Total: 1
==>  Preparing: SELECT id,name,age,email,is_delete FROM user WHERE is_delete=0 LIMIT ?
==> Parameters: 2(Long)
<==    Columns: id, name, age, email, is_delete
<==        Row: 2, hello, 33, 111@qq.com, 0
<==        Row: 3, hello, 18, 34567@qq.com, 0
<==      Total: 2

也可以很容易的获取分页相关的数据:

程序实例:

@Test
void contextLoads() {
    Page<User> page = new Page<>(1, 2);
    userMapper.selectPage(page, null);
    // 获取当前页的记录
    List<User> records = page.getRecords();
    records.forEach(System.out::println);
    // 获取当前页的页码
    long current = page.getCurrent();
    System.out.println(current);
    // 获取分页的总页码数
    long size = page.getSize();
    System.out.println(size);
    // 判断是否有下一页
    boolean b = page.hasNext();
    System.out.println(b);
    // 判断是否有上一页
    boolean b1 = page.hasPrevious();
    System.out.println(b1);
}

自定义分页功能

首先,定义一个mapper接口,返回一个Page对象:

Page<User> selectPageVo(@Param("page") Page<User> page, @Param("age") Integer age);

实现mapper接口:

<select id="selectPageVo" resultType="User">
    select id,name,age,email from user where age = #{age}
</select>

我们使用了类型别名,不要忘记在配置类中开启扫描类型别名所在的包:

mybatis-plus:
  ...
  # 配置类型别名对应的包
  type-aliases-package: com.klza.pojo

现在来测试一下吧:

@Test
void contextLoads() {
    Page<User> page = new Page<>(1, 2);
    Page<User> userPage = userMapper.selectPageVo(page, 18);
    System.out.println(userPage);
}

==>  Preparing: SELECT COUNT(*) AS total FROM user WHERE age = ?
==> Parameters: 18(Integer)
<==    Columns: total
<==        Row: 2
<==      Total: 1
==>  Preparing: select id,name,age,email from user where age = ? LIMIT ?
==> Parameters: 18(Integer), 2(Long)
<==    Columns: id, name, age, email
<==        Row: 3, hello, 18, 34567@qq.com
<==        Row: 4, hello, 18, 34567@qq.com
<==      Total: 2

到此这篇关于详解MyBatis Plus中分页插件的使用的文章就介绍到这了,更多相关MyBatis Plus分页插件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java中ArrayList 、LinkList的区别分析

    java中ArrayList 、LinkList的区别分析

    java中ArrayList 、LinkList的区别分析,需要的朋友可以参考一下
    2013-05-05
  • Spring超详细讲解IOC与解耦合

    Spring超详细讲解IOC与解耦合

    IoC就是比方说有一个类,我们想要调用类里面的方法(不是静态方法),就要创建该类的对象,使用对象调用方法来实现。但对于Spring来说,Spring创建对象的过程,不是在代码里面实现的,而是交给Spring来进行配置实现的
    2022-08-08
  • Java中的maven和gradle的比较与使用详解

    Java中的maven和gradle的比较与使用详解

    这篇文章主要介绍了maven和gradle的比较与使用,Maven使用基于XML的配置,Gradle采用了领域特定语言Groovy的配置,在Maven中要引入一个依赖,需要的朋友可以参考下
    2022-04-04
  • feign name指定服务调用无效问题及解决

    feign name指定服务调用无效问题及解决

    文章主要介绍了FeignClient注解的常用属性,并通过一个具体的例子说明了为什么某个Feign调用需要使用url指定路径才能访问,最后,文章给出了解决办法,即使用path属性指定前缀
    2024-11-11
  • Java并发编程如何降低锁粒度并实现性能优化

    Java并发编程如何降低锁粒度并实现性能优化

    这篇文章主要介绍了Java并发编程如何降低锁粒度并实现性能优化,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • 教你如何使用Java实现WebSocket

    教你如何使用Java实现WebSocket

    这篇文章主要介绍了教你如何使用Java实现WebSocket问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • SpringBoot+Kotlin中使用GRPC实现服务通信的示例代码

    SpringBoot+Kotlin中使用GRPC实现服务通信的示例代码

    本文主要介绍了SpringBoot+Kotlin中使用GRPC实现服务通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • ssh框架实现文件上传下载实例代码

    ssh框架实现文件上传下载实例代码

    本篇文章主要介绍了ssh框架文件上传下载实例代码,实例分析了Spring+struts+Hibernate的使用技巧,非常具有实用价值,需要的朋友可以参考下。
    2017-03-03
  • JAVA ServLet创建一个项目的基本步骤

    JAVA ServLet创建一个项目的基本步骤

    Servlet是Server Applet的简称,是运行在服务器上的小程序,用于编写Java的服务器端程序,它的主要作用是接收并响应来自Web客户端的请求,下面这篇文章主要给大家介绍了关于JAVA ServLet创建一个项目的基本步骤,需要的朋友可以参考下
    2024-03-03
  • MyBatis一次执行多条SQL语句的操作

    MyBatis一次执行多条SQL语句的操作

    这篇文章主要介绍了MyBatis一次执行多条SQL语句的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12

最新评论