MyBatis-Plus 插件扩展

news2024/9/23 5:18:14

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 {

    @Bean
    public 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;

    // 逻辑删除字段
    @TableLogic
    private 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 {

    @Bean
    public 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;

    @Version
    private Integer version;
}

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

@Configuration
public class MyBatisPlusConfig {

    @Bean
    public 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 {

    @Override
    public 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();
    }

    @Override
    public Object plugin(Object target) {
        return Plugin.wrap(target, this);
    }

    @Override
    public void setProperties(Properties properties) {
    }
}
3. 注册自定义插件

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

@Configuration
public class MyBatisPlusConfig {

    @Bean
    public 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.coloradmin.cn/o/2156657.html

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

相关文章

Java基础面试题——异常

目录 关系图 1. Throwable和Exception之间的关系 2.异常分为哪两大类 3.常见的 RuntimeException 4. 常见的 Error 5.什么是已检查异常和未检查异常&#xff1f;它们的区别是什么&#xff1f; 6.Java 中如何自定义异常&#xff1f; 7.throw 和 throws 的区别是什么&…

ML 系列:机器学习和深度学习的深层次总结(07)数据预处理—解决缺失值、异常值和错误数据

文章目录 一、说明二、数据预处理三、缺失值四、数据集中可能会出现多种类型的缺失值&#xff1a;五、处理缺失值的方法六、结论 一、说明 在AI数据挖掘中&#xff0c;对原始数据的预处理是必须的技术手段&#xff0c;本篇将对数据预处理的一系列注意事项进行展示。 二、数据…

JavaEE: 深入探索TCP网络编程的奇妙世界(五)

文章目录 TCP核心机制TCP核心机制六: 拥塞控制为什么要有拥塞控制?动态调整的拥塞控制拥塞控制中,窗口大小具体的变化过程 TCP核心机制七: 延时应答TCP核心机制八: 捎带应答 TCP核心机制 前一篇文章 JavaEE: 深入探索TCP网络编程的奇妙世界(四) 书接上文~ TCP核心机制六: 拥…

数据结构:二叉树OJ题(基础版)

前言 更完两期二叉树的知识之后&#xff0c;来做几道oj题巩固一下基础 一、翻转二叉树 链接&#xff1a;leetcode链接 还是分治思想&#xff0c;将问题分解成左子树和右子树交换&#xff0c;遇到空树停止 采用递归算法做题 TreeNode* invertTree(TreeNode* root) {if(root …

2D目标检测常用loss

在2D目标检测任务中&#xff0c;常用的损失函数&#xff08;Loss&#xff09;主要用于优化以下三个关键方面&#xff1a; 类别分类&#xff08;Classification&#xff09;&#xff1a;用于区分检测到的对象属于哪一类。边界框回归&#xff08;Bounding Box Regression&#x…

Spring Boot蜗牛兼职网:全栈开发

第4章 系统设计 4.1 系统体系结构 蜗牛兼职网的结构图4-1所示&#xff1a; 图4-1 系统结构 登录系统结构图&#xff0c;如图4-2所示&#xff1a; 图4-2 登录结构图 蜗牛兼职网结构图&#xff0c;如图4-3所示。 图4-3 蜗牛兼职网结构图 4.2开发流程设计 系统流程的分析是通…

在Web开发中使用和风天气接口

介绍 和风天气是一个提供全球天气预报和气象数据的服务平台&#xff0c;支持多种语言&#xff0c;提供实时天气、未来天气预报、空气质量指数、生活建议等多种气象数据&#xff0c;可以广泛用于网页开发、移动应用和物联网设备等场景。 开发文档&#xff1a;文档 | 和风天气开…

intellij idea 控制台运行java出现中文乱码的解决方法

原因&#xff1a; 字符编码不一致&#xff1a; 当你在intellij idea使用了UTF-8编码&#xff0c;而在控制台使用了其他编码&#xff08;比如gbk&#xff09;&#xff0c;就可能导致乱码。 文件读写编码问题&#xff1a; 如果读取文件时使用的编码与文件实际编码不一致&#xf…

Chainlit集成LlamaIndex实现知识库高级检索(自动合并检索)

检索原理 自动合并检索 自动合并检索原理&#xff0c;和我的上一篇文章的检索方案&#xff1a; 将文本分割成512大小&#xff08;一般对应段落大小&#xff09;和128&#xff08;一般对句子大小不是严格的句子长度&#xff09;大小两种分别存储到索引库&#xff0c;再用llama_…

《深度学习》—— 卷积神经网络(CNN)的简单介绍和工作原理

文章目录 一、卷积神经网络的简单介绍二、工作原理(还未写完)1.输入层2.卷积层3.池化层4.全连接层5.输出层 一、卷积神经网络的简单介绍 基本概念 定义&#xff1a;卷积神经网络是一种深度学习模型&#xff0c;通常用于图像、视频、语音等信号数据的分类和识别任务。其核心思想…

如何在Markdown写文章上传到wordpress保证图片不丢失

如何在Markdown写文章上传到wordpress保证图片不丢失 写文日期,2023-11-16 引文 众所周知markdown是一款nb的笔记软件&#xff0c;本篇文章讲解如何在markdown编写文件后上传至wordpress论坛。并且保证图片不丢失&#xff08;将图片上传至云端而非本地方法&#xff09; 一&…

通信工程学习:什么是NFVI网络功能虚拟化基础设施层

NFVI&#xff1a;网络功能虚拟化基础设施层 NFVI&#xff08;Network Functions Virtualization Infrastructure&#xff09;即网络功能虚拟化基础设施层&#xff0c;是NFV&#xff08;Network Functions Virtualization&#xff0c;网络功能虚拟化&#xff09;架构中的一个重要…

精准农业中遥感技术应用(五)- 一站式遥感数据服务平台AIEarth

橙蜂智能公司致力于提供先进的人工智能和物联网解决方案&#xff0c;帮助企业优化运营并实现技术潜能。公司主要服务包括AI数字人、AI翻译、领域知识库、大模型服务等。其核心价值观为创新、客户至上、质量、合作和可持续发展。 橙蜂智农的智慧农业产品涵盖了多方面的功能&…

【LeetCode:116. 填充每个节点的下一个右侧节点指针 + BFS(层次遍历)】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…

redis主从复制的理论和实战详细教程

0 前言 就是主从复制&#xff0c;master以写为主&#xff0c;slave以读为主&#xff0c;当master数据变化的时候&#xff0c;自动将新的数据异步同步到其他的slave数据库。也就是redis主从复制异步同步数据的&#xff0c;所以在主从架构中使用分布式锁时&#xff0c;可能会出现…

4--SpringBoot项目中分类管理

目录 新增分类 分类分页查询 启用禁用分类 根据类型查询 修改分类 本文介绍SpringBoot项目中的分类管理&#xff0c;操作类似员工管理模块&#xff0c;具体详解可见以下博客&#xff0c;此处给出各部分代码 2--SpringBoot项目中员工管理 详解&#xff08;一&#xff09;-C…

基于51单片机的手环设计仿真

目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 基于STC89C52单片机&#xff0c;DHT11温湿度采集温湿度&#xff0c;滑动变阻器连接ADC0832数模转换器模拟水位传感器检测水位&#xff0c;通过LCD1602显示信息&#xff0c;然后在程序里设置好是否…

vue3项目中引入词云图

在vue3中的项目引入词云图 前言&#xff1a;先看效果图步骤如下 前言&#xff1a; 公司产品要求项目中使用词云图&#xff0c;我算是第一次用&#xff0c;于是在网上查找资料&#xff0c;最后做出来了。 先看效果图 步骤如下 npm i echarts-wordcloud -S <template> …

恶意AI大模型的兴起将改变网络安全

LLM 的恶意版本&#xff08;如 ChatGPT 的黑暗变体&#xff09;的兴起正在通过使用更复杂和自动化的攻击来升级网络战。 这些模型可以生成令人信服的网络钓鱼电子邮件、传播虚假信息并制作有针对性的社会工程消息。 所有这些非法功能都对在线安全构成了重大威胁&#xff0c;并加…

2024年最新前端工程师 TypeScript 基础知识点详细教程(更新中)

1. TypeScript 概述 TypeScript 是由微软开发的、基于 JavaScript 的一种强类型编程语言。它是在 JavaScript 的基础上添加了静态类型检查、面向对象编程等功能的超集&#xff0c;最终会被编译为纯 JavaScript 代码。由于其扩展了 JavaScript 的功能&#xff0c;TypeScript 特…