MyBatis-Plus 插件扩展

MyBatis-Plus 插件扩展详解

MyBatis-Plus 提供了丰富的插件扩展机制,允许开发者通过插件实现增强功能或定制化操作。通过插件机制,开发者可以轻松扩展 MyBatis-Plus 的功能,从而满足复杂的业务需求。

一、MyBatis-Plus 插件的工作原理

MyBatis-Plus 的插件机制基于 MyBatis 提供的 Interceptor 拦截器。MyBatis 拦截器可以对 MyBatis 的四大核心对象进行拦截和增强操作:

  1. Executor:负责执行 SQL 语句,如增删改查等操作。
  2. StatementHandler:负责处理 SQL 语句的生成和参数设置。
  3. ResultSetHandler:负责处理 SQL 语句执行后的结果集。
  4. ParameterHandler:负责处理 SQL 语句中的参数绑定。

MyBatis-Plus 的插件机制是在 MyBatis 拦截器的基础上扩展的。通过插件,开发者可以对 SQL 执行过程进行拦截、修改和优化。

二、MyBatis-Plus 常用插件

MyBatis-Plus 提供了许多内置的插件,帮助开发者快速实现常见的功能需求。

1. 分页插件

分页查询是数据库操作中常见的需求。MyBatis-Plus 提供了分页插件,自动为分页查询生成分页 SQL,避免手写分页逻辑。

配置分页插件:

MyBatisPlusConfig 中配置分页插件:

@Configuration
public class MyBatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();// 配置分页插件interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;}
}

分页查询代码示例:

Page<User> page = new Page<>(1, 10);  // 第1页,每页10条
LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.ge(User::getAge, 18);
Page<User> userPage = userMapper.selectPage(page, queryWrapper);

selectPage 会根据分页插件生成的分页 SQL 查询数据,返回结果包含分页的详细信息,如总条数、总页数等。

2. 逻辑删除插件

逻辑删除允许在不删除数据库记录的情况下标记记录为已删除。MyBatis-Plus 提供了内置的逻辑删除支持,通过简单的配置即可实现。

配置逻辑删除插件:

首先,在实体类中定义逻辑删除字段,并使用 @TableLogic 注解标记:

@Data
public class User {private Long id;private String name;private Integer age;// 逻辑删除字段@TableLogicprivate Integer deleted;
}

application.yml 中配置逻辑删除:

mybatis-plus:global-config:db-config:logic-delete-field: deleted  # 设置逻辑删除字段

当调用 deleteById 方法时,MyBatis-Plus 不会真正删除数据,而是将 deleted 字段设置为 1:

userMapper.deleteById(1L);  // 实际执行:UPDATE user SET deleted = 1 WHERE id = 1

同时,查询时 MyBatis-Plus 会自动过滤已逻辑删除的记录。

3. SQL 性能分析插件

SQL 性能分析插件用于开发环境中分析 SQL 的执行性能,帮助开发者优化 SQL 查询。

配置 SQL 性能分析插件:

@Configuration
public class MyBatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();// 配置性能分析插件interceptor.addInnerInterceptor(new PerformanceInnerInterceptor());return interceptor;}
}

启用后,SQL 性能分析插件会在控制台输出每次 SQL 执行的时间,方便开发者优化查询性能。

4. 乐观锁插件

乐观锁用于解决并发问题,MyBatis-Plus 提供了内置的乐观锁插件,通过版本号控制数据的更新。

配置乐观锁插件:

在实体类中定义版本号字段,并使用 @Version 注解:

@Data
public class User {private Long id;private String name;private Integer age;@Versionprivate Integer version;
}

在配置类中注册乐观锁插件:

@Configuration
public class MyBatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();// 配置乐观锁插件interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());return interceptor;}
}

更新操作时,MyBatis-Plus 会自动检查版本号,确保并发时数据不会被覆盖。

三、自定义插件

除了使用 MyBatis-Plus 提供的内置插件,开发者还可以根据自己的业务需求,编写自定义插件。自定义插件可以拦截 MyBatis 执行过程中的 SQL 语句或操作逻辑,进行功能增强。

1. 自定义插件步骤

自定义插件通常需要以下几个步骤:

  1. 实现 Interceptor 接口:定义一个类实现 MyBatis 的 Interceptor 接口,覆盖 intercept() 方法,编写拦截逻辑。
  2. 注册插件:将自定义插件注册到 MyBatis-Plus 中。
2. 自定义插件示例

下面我们实现一个简单的自定义插件,用于在 SQL 执行前输出 SQL 语句到控制台。

public class MyCustomInterceptor implements Interceptor {@Overridepublic Object intercept(Invocation invocation) throws Throwable {// 获取执行的 SQL 语句Object[] args = invocation.getArgs();MappedStatement mappedStatement = (MappedStatement) args[0];BoundSql boundSql = mappedStatement.getBoundSql(args[1]);String sql = boundSql.getSql();System.out.println("执行的 SQL: " + sql);// 执行原始操作return invocation.proceed();}@Overridepublic Object plugin(Object target) {return Plugin.wrap(target, this);}@Overridepublic void setProperties(Properties properties) {}
}
3. 注册自定义插件

将自定义插件注册到 MyBatis-Plus 配置中:

@Configuration
public class MyBatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();// 注册自定义插件interceptor.addInnerInterceptor(new MyCustomInterceptor());return interceptor;}
}

运行应用程序后,每次执行 SQL 语句时,自定义插件都会拦截并输出 SQL 到控制台。

四、插件扩展注意事项

  1. 插件顺序:MyBatis-Plus 支持多个插件,多个插件会按照注册的顺序依次执行。开发者在编写自定义插件时,应注意插件的执行顺序,以避免插件之间的冲突。

  2. 性能影响:虽然插件可以增强 MyBatis-Plus 的功能,但过多的插件可能会对性能产生影响,特别是在高并发场景中,应避免不必要的插件使用。

  3. 使用场景:MyBatis-Plus 的插件机制适用于多种场景,开发者可以根据业务需求选择合适的插件,或自定义插件来增强 MyBatis-Plus 的功能。但要注意的是,插件主要适用于 SQL 执行相关的功能扩展,对于复杂的业务逻辑处理,应在业务层进行。

五、总结

MyBatis-Plus 提供了强大的插件扩展机制,通过插件可以轻松实现分页、逻辑删除、SQL 性能分析、乐观锁等常见功能。MyBatis-Plus 内置的插件已经覆盖了大多数开发需求,开发者只需要简单配置即可使用。如果有特殊的业务需求,开发者还可以通过实现自定义插件对 MyBatis-Plus 的 SQL 执行过程进行干预和扩展。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/880025.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux中使用cp命令的 -f 选项,但还是提醒覆盖的问题

问题&#xff1a; linux 在执行cp的命令的时候&#xff0c;就算是执行 cp -f 也还是会提醒是否要进行替换。 问题原因&#xff1a; 查看别名&#xff0c;alias命令&#xff0c;看到cp的别名为cp -i&#xff0c;那就是说cp本身就是自带覆盖提醒&#xff0c;就算我们加上-f 的…

JavaEE初阶——初识EE(Java诞生背景,CPU详解)

阿华代码&#xff0c;不是逆风&#xff0c;就是我疯&#xff0c;你们的点赞收藏是我前进最大的动力&#xff01;&#xff01;希望本文内容能帮到你&#xff01; 目录 零&#xff1a;Java的发展背景介绍 一&#xff1a;EE的概念 二&#xff1a;计算机的构成 1&#xff1a;CU…

五、CAN总线

目录 一、基础知识 1、can介绍 2、CAN硬件电路 3、CAN电平标准 4、CAN收发器芯片介绍 5、CAN帧格式 ① CAN帧种类 ② CAN数据帧 ③ CAN遥控帧​编辑 ④ 位填充 ⑤ 波形实例 6、接收方数据采样 ① 接收方数据采样遇到的问题 ② 位时序 ③ 硬同步 ④ 再同步 ⑤ 波…

Java的IO流(二)

目录 Java的IO流&#xff08;二&#xff09; 字节缓冲流 基本使用 使用缓冲流复制文件 字符缓冲流 缓冲流读取数据原理 字符编码 字符集 转换流 序列化流与反序列化流 基本使用 禁止成员被序列化 序列号不匹配异常 打印流 基本使用 系统打印流与改变流向 Prop…

【网络安全】依赖混淆漏洞实现RCE

未经许可&#xff0c;不得转载。 文章目录 正文 依赖混淆是一种供应链攻击漏洞&#xff0c;发生在企业的内部依赖包错误地从公共库&#xff08;如npm&#xff09;下载&#xff0c;而不是从其私有注册表下载。攻击者可以在公共注册表中上传一个与公司内部包同名的恶意包&#xf…

【深入理解SpringCloud微服务】了解微服务的熔断、限流、降级,手写实现一个微服务熔断限流器

【深入理解SpringCloud微服务】了解微服务的熔断、限流、降级&#xff0c;手写实现一个微服务熔断限流器 服务雪崩熔断、限流、降级熔断降级限流 手写实现一个微服务熔断限流器架构设计代码实现整体逻辑ProtectorAspect#aroundMethod(ProceedingJoinPoint)具体实现1、获取接口对…

低级编程语言和高级编程语言

一.区分低级编程语言和高级编程语言的方法 1.低级编程语言 低级编程语言,并不是简单的编程语言,而是写起来很费事的编程语言,如所有编程语言的"祖宗":汇编语言,写起来极其麻烦,说不定一个 int a1; 它就得写好几行,甚至十几行 这样麻烦的编程语言为什么还没消失那,因…

P9235 [蓝桥杯 2023 省 A] 网络稳定性

*原题链接* 最小瓶颈生成树题&#xff0c;和货车运输完全一样。 先简化题意&#xff0c; 次询问&#xff0c;每次给出 &#xff0c;问 到 的所有路径集合中&#xff0c;最小边权的最大值。 对于这种题可以用kruskal生成树来做&#xff0c;也可以用倍增来写&#xff0c;但不…

react:组件通信

组件通信 父组件向子组件通信 function App() {return (<div><div>这是父组件</div><Child name"这是子组件" /></div>); }// 子组件 function Child(props) {return <div>{props.name}</div>; }props说明 props可以传…

[Python学习日记-26] Python 中的文件操作

[Python学习日记-26] Python 中的文件操作 简介 操作模式 循环文件 其他功能 混合模式 修改文件 简介 在 Python 中的文件操作其实和我们平时使用的 Word 的操作是比较类似的&#xff0c;我们先说一下 Word 的操作流程&#xff0c;流程如下&#xff1a; 找到文件&#x…

re题(39)BUUCTF-[FlareOn3]Challenge1

BUUCTF在线评测 (buuoj.cn) 查壳是32位&#xff0c;ida打开&#xff0c;进入main函数&#xff0c;进入sub_401260看看 查看byte_413000存的字符串 _BYTE *__cdecl sub_401260(int a1, unsigned int a2) {int v3; // [espCh] [ebp-24h]int v4; // [esp10h] [ebp-20h]int v5; //…

python selenium网页操作

一、安装依赖 pip install -U seleniumselenium1.py&#xff1a; from selenium import webdriver from selenium.webdriver.common.by import Bydriver webdriver.Chrome() driver.get("https://www.selenium.dev/selenium/web/web-form.html") title driver.ti…

https的连接过程

根证书: 内置在操作系统和浏览器中,可手动添加,下级是中间证书或服务器证书,只有当中间证书或服务器证书关联到已存在的根证书时,中间证书或服务器证书才视为有效 中间证书: 位于根证书和服务器证书之间,他们之间也可以没有中间证书,作用是对根证书增加一个下级,方便管理,由根…

整合多方大佬博客以及视频 一文读懂 servlet

参考文章以及视频 文章&#xff1a; 都2023年了&#xff0c;Servlet还有必要学习吗&#xff1f;一文带你快速了解Servlet_servlet用得多吗-CSDN博客 【计算机网络】HTTP 协议详解_3.简述浏览器请求一个网址的过程中用到的网络协议,以及协议的用途(写关键点即可)-CSDN博客 【…

yolov8旋转目标检测之绝缘子检测-从数据加载到模型训练、部署

YOLOv8 是 YOLO (You Only Look Once) 系列目标检测算法的最新版本&#xff0c;以其高速度和高精度而著称。在电力行业中&#xff0c;绝缘子是电力传输线路上的重要组件之一&#xff0c;它们用于支撑导线并保持电气绝缘。由于长期暴露在户外环境中&#xff0c;绝缘子容易出现损…

【JavaEE】多线程编程引入——认识Thread类

阿华代码&#xff0c;不是逆风&#xff0c;就是我疯&#xff0c;你们的点赞收藏是我前进最大的动力&#xff01;&#xff01;希望本文内容能帮到你&#xff01; 目录 引入&#xff1a; 一&#xff1a;Thread类 1&#xff1a;Thread类可以直接调用 2&#xff1a;run方法 &a…

【25.6】C++智能交友系统

常见错误总结 const-1 如下代码会报错 原因如下&#xff1a; man是一个const修饰的对象&#xff0c;即man不能修改任何内容&#xff0c;但是man所调用的play函数只是一个普通的函数&#xff0c;所以出现了报错。我们需要在play函数中加上const修饰&#xff0c;或者删除man对…

【计算机网络 - 基础问题】每日 3 题(十八)

✍个人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/fYaBd &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞&#x1f44d;收藏&…

SpringBoot环境配置(Spring Boot Profile)

一、介绍 在Spring Boot中&#xff0c;spring.profiles 配置用于定义不同环境下的配置文件。这使得应用可以在不同的环境中使用不同的配置&#xff0c;比如开发环境、测试环境和生产环境等。这种方式可以避免在代码中硬编码配置信息&#xff0c;并且能够更灵活地管理应用的环境…

SpringBootWeb增删改查入门案例

前言 为了快速入门一个SpringBootWeb项目&#xff0c;这里就将基础的增删改查的案例进行总结&#xff0c;作为对SpringBootMybatis的基础用法的一个巩固。 准备工作 需求说明 对员工表进行增删改查操作环境搭建 准备数据表 -- 员工管理(带约束) create table emp (id int …