MyBatis Plus 会在执行 SQL 查询时自动应用拦截器链,包括分页拦截器,从而简化分页逻辑的处理

java 复制代码
public MybatisPlusInterceptor mybatisPlusInterceptor(){
        MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
        mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor());
        return mybatisPlusInterceptor;
    }

这段代码定义了一个名为 mybatisPlusInterceptor 的方法,它创建并配置了一个 MybatisPlusInterceptor 对象,然后返回这个对象。以下是对代码的详细解释:

  1. 方法定义

    • public MybatisPlusInterceptor mybatisPlusInterceptor():这是一个公共方法,返回类型为 MybatisPlusInterceptor
  2. 创建 MybatisPlusInterceptor 实例

    • MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();:这行代码创建了 MybatisPlusInterceptor 类的一个新实例。
  3. 添加内部拦截器

    • mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor());:这行代码向 MybatisPlusInterceptor 对象中添加了一个名为 PaginationInnerInterceptor 的内部拦截器。PaginationInnerInterceptor 是 MyBatis Plus 中用于处理 SQL 分页的拦截器。
  4. 返回配置好的拦截器

    • return mybatisPlusInterceptor;:方法返回配置好的 MybatisPlusInterceptor 实例。

作用:

  • MybatisPlusInterceptor 是 MyBatis Plus 框架中的一个组件,用于拦截 MyBatis 的 SQL 执行过程,以便进行一些自定义操作,如修改 SQL、性能监控、事务控制等。
  • PaginationInnerInterceptor 是 MyBatis Plus 提供的一个内置拦截器,用于自动处理 SQL 的分页逻辑。当使用这个拦截器时,MyBatis Plus 会自动将查询结果限制在指定的页码和每页条数内。

使用场景:

  • 当你想要全局性地添加 MyBatis 拦截器时,可以在 Spring 框架的配置类中添加类似的方法,并使用 @Bean 注解将其注册为 Spring 容器中的 Bean。

示例:

java 复制代码
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
@MapperScan("com.example.project.mapper")
public class MybatisPlusConfig {

    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
        mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor());
        return mybatisPlusInterceptor;
    }
}

在这个示例中,我们创建了一个配置类 MybatisPlusConfig,并定义了一个 mybatisPlusInterceptor Bean。通过 @Bean 注解,Spring 容器会自动调用这个方法并注册 MybatisPlusInterceptor Bean。同时,我们使用 @MapperScan 注解来指定 MyBatis Mapper 接口所在的包路径。

这样配置后,MyBatis Plus 会在执行 SQL 查询时自动应用拦截器链,包括分页拦截器,从而简化分页逻辑的处理。

相关推荐
roman_日积跬步-终至千里35 分钟前
【Java并发】Java 线程池实战:警惕使用CompletableFuture.supplyAsync
java·开发语言·网络
毕设源码-钟学长37 分钟前
【开题答辩全过程】以 基于Springboot的扶贫众筹平台为例,包含答辩的问题和答案
java·spring boot·后端
CodeSheep程序羊1 小时前
拼多多春节加班工资曝光,没几个敢给这个数的。
java·c语言·开发语言·c++·python·程序人生·职场和发展
我是咸鱼不闲呀1 小时前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
加油,小猿猿2 小时前
Java开发日志-双数据库事务问题
java·开发语言·数据库
yuluo_YX2 小时前
Reactive 编程 - Java Reactor
java·python·apache
山岚的运维笔记2 小时前
SQL Server笔记 -- 第20章:TRY/CATCH
java·数据库·笔记·sql·microsoft·sqlserver
南极企鹅2 小时前
springBoot项目有几个端口
java·spring boot·后端
清风拂山岗 明月照大江3 小时前
Redis笔记汇总
java·redis·缓存
xiaoxue..3 小时前
合并两个升序链表 与 合并k个升序链表
java·javascript·数据结构·链表·面试