当前位置: 首页 > news >正文

SpringCloud-持久层框架MyBatis Plus的使用与原理详解

在现代微服务架构中,SpringCloud 是一个非常流行的解决方案。而在数据库操作层面,MyBatis Plus 作为 MyBatis 的增强工具,能够简化开发,提升效率,特别是在开发企业级应用和分布式系统时尤为有用。本文将详细介绍 MyBatis Plus 的使用方法、原理及其与 MyBatis 的区别。

在这里插入图片描述


一、MyBatis Plus 简介

1. MyBatis 简介

MyBatis 是一个优秀的 ORM 框架,它通过 XML 或注解的方式将 Java 方法与 SQL 语句进行映射,并且可以灵活地控制 SQL 执行的各个细节,提供极高的自由度。它广泛应用于项目中,尤其是在对 SQL 语句要求比较严格的场景中。

2. MyBatis Plus 介绍

MyBatis Plus 是在 MyBatis 的基础上进行增强的持久层框架,专注于简化 MyBatis 的开发工作。它封装了常用的 CRUD 操作,极大地减少了开发者编写 SQL 的工作量。其目标是“更少的配置,更多的功能”,通过插件机制提供更强大的功能扩展。

3. MyBatis 与 MyBatis Plus 的对比

对比项MyBatisMyBatis Plus
核心理念手写 SQL,灵活但需要大量的 SQL 代码自动化 CRUD,大大减少手写 SQL
SQL 编写需要手动编写所有 SQL 语句提供默认 CRUD 接口,只需少量自定义 SQL
复杂查询需要手动编写复杂 SQL 语句提供条件构造器,简化复杂查询操作
分页需要手动编写分页逻辑内置分页插件,简化分页操作
性能优化自定义 SQL 性能优化较灵活提供多种插件支持性能优化,如 SQL 执行分析插件
代码生成不支持代码生成提供自动代码生成器,支持一键生成 Mapper、Service 等
扩展能力通过配置扩展内置多种插件机制,支持扩展,如乐观锁、审计等

通过这张对比表可以看出,MyBatis Plus 在开发效率和功能扩展上具有显著优势,尤其在企业级开发中,可以大大简化数据库操作的工作。


二、MyBatis Plus 的基本使用

1. 基础依赖和配置

要在 SpringCloud 中使用 MyBatis Plus,首先需要在项目的 pom.xml 中添加 MyBatis Plus 的依赖:

<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.3.4</version>
</dependency>

接下来,在 application.yml 中配置数据库连接:

spring:datasource:url: jdbc:mysql://localhost:3306/your_database?useSSL=falseusername: rootpassword: your_passwordmybatis-plus:mapper-locations: classpath:/mapper/*.xml

2. 实体类的定义

在 MyBatis Plus 中,实体类是映射数据库表的核心。在实体类中,常用 @TableName@TableId 注解来映射表和主键。

@Data
@TableName("user")
public class User {@TableId(type = IdType.AUTO)private Long id;private String name;private Integer age;private String email;
}

3. Mapper 接口的编写

Mapper 接口是 MyBatis Plus 提供的基础 CRUD 接口,继承 BaseMapper 就可以拥有常用的 CRUD 功能,无需额外编写 SQL。

public interface UserMapper extends BaseMapper<User> {
}

4. Service 层的实现

为了更好地管理业务逻辑,通常会在 Service 层中编写业务方法。可以通过注入 Mapper 来实现对数据库的操作。

@Service
public class UserService {@Autowiredprivate UserMapper userMapper;public List<User> getAllUsers() {return userMapper.selectList(null);}public void createUser(User user) {userMapper.insert(user);}
}

三、MyBatis Plus 的高级用法

1. 分页插件

分页是大多数系统必备的功能。MyBatis Plus 内置分页插件,可以通过简单的配置实现高效分页。

@Autowired
private UserMapper userMapper;public IPage<User> getUsersPage(int pageNum, int pageSize) {Page<User> page = new Page<>(pageNum, pageSize);return userMapper.selectPage(page, null);
}

2. 乐观锁插件

MyBatis Plus 支持乐观锁,防止多个用户同时修改同一条数据时的并发问题。可以通过在实体类上添加 @Version 注解来启用乐观锁功能。

@Data
@TableName("user")
public class User {@TableId(type = IdType.AUTO)private Long id;private String name;private Integer age;private String email;@Versionprivate Integer version; // 乐观锁版本字段
}

3. 多租户插件

MyBatis Plus 提供了多租户插件,支持在多租户架构中为每个租户分配独立的数据空间,避免数据泄露或冲突。

@Configuration
public class MybatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();// 多租户插件配置TenantLineInnerInterceptor tenantLineInnerInterceptor = new TenantLineInnerInterceptor();interceptor.addInnerInterceptor(tenantLineInnerInterceptor);return interceptor;}
}

4. 自动填充功能

MyBatis Plus 支持自动填充常见字段,如创建时间、更新时间等。可以通过 @TableField 注解配置字段的自动填充策略。

@Data
@TableName("user")
public class User {@TableId(type = IdType.AUTO)private Long id;private String name;private Integer age;private String email;@TableField(fill = FieldFill.INSERT)private Date createTime; // 自动填充创建时间@TableField(fill = FieldFill.INSERT_UPDATE)private Date updateTime; // 自动填充更新时间
}

5. 逻辑删除功能

逻辑删除是一种不物理删除数据,而是通过标记删除状态的方式实现删除。MyBatis Plus 提供了逻辑删除支持,可以通过 @TableLogic 注解实现。

@Data
@TableName("user")
public class User {@TableId(type = IdType.AUTO)private Long id;private String name;private Integer age;private String email;@TableLogicprivate Integer deleted; // 逻辑删除字段
}

四、MyBatis Plus 原理详解

MyBatis Plus 的原理是基于 MyBatis 的核心功能进行增强,主要通过 插件机制代码生成机制 提供额外的功能支持。

1. 基于 MyBatis 核心的增强

MyBatis Plus 是对 MyBatis 的扩展和增强,在 MyBatis 的基础上引入了大量的插件和自定义功能。例如,通过扩展 BaseMapper,MyBatis Plus 为所有实体类提供了基础的 CRUD 功能,开发者无需编写重复的 SQL。

2. 插件机制

MyBatis Plus 的插件机制非常灵活,允许开发者自定义插件,扩展 MyBatis Plus 的功能。MyBatis Plus 通过 责任链模式 处理多个插件请求,插件之间通过 链式调用 实现功能的扩展。

常见的插件包括:

  • 分页插件:通过在 SQL 执行前后进行拦截,实现分页功能。
  • 多租户插件:通过在 SQL 中自动加入租户 ID 实现数据隔离。
  • 乐观锁插件:通过在 SQL 中自动加入版本号实现并发控制。

3. 条件构造器

MyBatis Plus 提供了 条件构造器,简化了复杂 SQL 的拼装过程。条件构造器基于 Lambda 表达式,能够灵活构建动态查询条件,极大地简化了 SQL 的编写工作。

QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.lambda().eq(User::getName, "Tom").ge(User::getAge, 18);
List<User> users = userMapper.selectList(queryWrapper);

4. 自动代码生成器

MyBatis Plus 提供了自动代码生成器,支持通过数据库表结构自动生成实体类、Mapper、Service、Controller 等层的代码,大幅减少手工编写代码的工作量。这一特性非常适合大型项目和快速迭代开发的场景。

5. 动态 SQL 解析

MyBatis Plus 支持动态 SQL 解析,通过注解或 XML 方式在运行时解析 SQL,生成最终的 SQL 语句。这种方式使得 SQL 编写更加灵活,能够适应复杂的业务逻辑。


五、MyBatis Plus 的使用总结

MyBatis Plus 在简化 MyBatis 开发工作、提升开发效率和灵活性方面表现出色。它不仅保留了 MyBatis 的强大 SQL 自定义功能,还通过插件机制和自动化工具提供了更多的扩展功能。

MyBatis Plus 的核心优势:

优势说明
自动化 CRUD通过内置的 CRUD 接口,减少了开发者手动编写 SQL 的工作量。
分页和多租户支持MyBatis Plus 内置分页和多租户插件,能够轻松处理复杂的查询场景。
性能优化通过插件机制和缓存机制,MyBatis Plus 提供多种性能优化手段,保证高效的数据库操作。
代码生成器自动生成常用代码,提升开发效率,加快项目开发速度。

总之,MyBatis Plus 是 SpringCloud 项目中非常优秀的持久层框架。通过其丰富的功能和灵活的扩展机制,可以大幅提升开发效率,特别适用于大规模分布式系统的开发。

在这里插入图片描述

相关文章:

SpringCloud-持久层框架MyBatis Plus的使用与原理详解

在现代微服务架构中&#xff0c;SpringCloud 是一个非常流行的解决方案。而在数据库操作层面&#xff0c;MyBatis Plus 作为 MyBatis 的增强工具&#xff0c;能够简化开发&#xff0c;提升效率&#xff0c;特别是在开发企业级应用和分布式系统时尤为有用。本文将详细介绍 MyBat…...

Servlet的HttpServletRequest

HttpServletRequest是Java Servlet规范中定义的一个接口&#xff0c;它表示客户端向服务器发送的请求&#xff0c;并提供了与HTTP请求相关的方法和属性。 getSession方法()&#xff1a;用于获取与当前请求相关联的HttpSession对象。 setAttribute(String name, Object value)…...

U9销售订单不能带出最新价格出来

业务员突然说系统带不出来销售价格。了解之后&#xff0c;不是带不出来价格&#xff0c;是做了价格调整之后&#xff0c;最新价格没有匹配出来&#xff0c;带出来的价格是历史价格。检查&#xff0c;分析相关的单据&#xff0c;生效日期&#xff0c;失效日期&#xff0c;审核状…...

Jmeter接口测试企业级项目实战day1

1.接口测试 接口测试工具&#xff1a; JMeter&#xff1a;支持多种接口类型&#xff0c;还能测试性能&#xff0c;开源&#xff0c;开源进行二次扩展。 Postman&#xff1a;简单&#xff0c;方便&#xff0c;局限性比较大&#xff0c;适合开发临时行调试 APIFox等&#xff1a;新…...

接口测试面试题含答案

1、解释一下正向和逆向测试。 正向测试&#xff1a;针对接口设计预期的功能和行为&#xff0c;验证接口是否按照预期工作。 逆向测试&#xff1a;针对错误输入、不合理的条件或非预期的使用方式&#xff0c;验证接口是否能够适当地处理这些情况并提供合理的错误处理。 2、什…...

横板营业执照提取生成

前言 有一段时间没发博客了&#xff0c;今天分享下几个月前做的营业执照提取器UI 预览图 框架 b-ui很好用&#xff0c;这个前端框架作者 发布的插件我都会用&#xff0c;鱿鱼助手也是基于这个框架开发的 代码 html <template><view><template><view…...

webm格式怎么转换成mp4?这5种转换方法很好用

现如今&#xff0c;视频格式繁多&#xff0c;而webm作为一种由谷歌开发的视频格式&#xff0c;以其高画质和低带宽需求著称。然而&#xff0c;并非所有设备和播放器都完美支持webm格式&#xff0c;这时将其转换为兼容性更强的MP4格式就显得尤为重要。下面给大家分享5种非常简单…...

C/C++语言基础--C++异常看这一篇就够了

本专栏目的 更新C/C的基础语法&#xff0c;包括C的一些新特性 前言 通过前面几节课&#xff0c;我们学习了抽象、封装、继承、多态等相关的概念&#xff0c;接下来我们将讲解异常&#xff0c;异常是专门处理错误的&#xff1b;这一次加了不少图标&#xff0c;希望大家喜欢;C语…...

DFT ATPG中常见影响coverage的因素有哪些?

# DFT ATPG中常见影响Coverage的因素 ## 一、电路结构复杂性 1. **逻辑层次深度** - **原理** - 当电路的逻辑层次很深时,信号在传播过程中会经过多个逻辑门的处理。这使得测试向量难以准确地控制和观察内部节点的状态。例如,在一个具有多层嵌套逻辑的电路中,如一个…...

Python机器学习数据清洗到特征工程策略

Python机器学习数据清洗到特征工程策略 目录 ✨ 数据清洗&#xff1a;处理缺失值与异常值的策略&#x1f504; 特征选择&#xff1a;筛选与数据目标高度相关的特征&#x1f6e0; 特征工程&#xff1a;数据转换与生成新特征的多样化方法&#x1f4ca; 类别型变量的数值化&…...

多线程-进阶(2)CountDownLatchConcurrentHashMapSemaphore

目的; JUC(java.util.concurrent) 的常⻅类 接着上一节课到 1.信号量 Semaphore 信号量, ⽤来表⽰ "可⽤资源的个数". 本质上就是⼀个计数器。 理解信号量 可以把信号量想象成是停⻋场的展⽰牌: 当前有⻋位 100 个. 表⽰有 100 个可⽤资源. 当有⻋开进去的时候,…...

密码管理器KeePass的安装及使用

文章目录 软件下载安装汉化新建数据库创建\移动\修改 群组添加/修改/删除/移动 记录展示、搜索、锁定单独使用keepass生成密码的功能AES-256的密钥长度为256位&#xff0c;为啥可以设置超过32个字符的密钥&#xff1f; 软件下载 安装 分别解压&#xff1a;KeePass-2.53.1.zip&…...

星海智算:【萤火遛AI-Stable-Diffusion】无需部署一键启动

部署流程 1、注册算力云平台&#xff1a;星海智算 https://gpu.spacehpc.com/ 2、创建实例&#xff0c;镜像请依次点击&#xff1a;“镜像市场”->“更换”->“AI绘画”->“萤火遛AI-Stable Diffusion”。 程序首次启动可能需要几分钟&#xff0c;待实例显示“运行…...

JS生成器的特殊用法:委托yield*

yield 的基本用法 yield 用于在生成器函数中暂停函数执行&#xff0c;并返回一个值给外部调用者。当生成器再次被调用时&#xff0c;会从暂停的地方继续执行。 示例&#xff1a; function* simpleGenerator() {yield 1;yield 2;yield 3; }const gen simpleGenerator();cons…...

【CuPy报错】NVRTC_ERROR_COMPILATION (6)找不到 ‘vector_types.h‘

cupy安装不要再使用pip install cupy了&#xff0c; 已经替换成基于版本安装了pip install cupy-cuda12x&#xff0c;详见cupy官网。 安装完成后&#xff0c;在import cupy之后报错&#xff0c;找不到 ‘vector_types.h’: CompileException: /home/zoe/venv/lib/python3.10/…...

机器学习:知识蒸馏(Knowledge Distillation,KD)

知识蒸馏&#xff08;Knowledge Distillation&#xff0c;KD&#xff09;作为深度学习领域中的一种模型压缩技术&#xff0c;主要用于将大规模、复杂的神经网络模型&#xff08;即教师模型&#xff09;压缩为较小的、轻量化的模型&#xff08;即学生模型&#xff09;。在实际应…...

【C++入门篇 - 3】:从C到C++第二篇

文章目录 从C到C第二篇new和delete命名空间命名空间的访问 cin和coutstring的基本使用 从C到C第二篇 new和delete 在C中用来向系统申请堆区的内存空间 New的作用相当于C语言中的malloc Delete的作用相当于C语言中的free 注意&#xff1a;在C语言中&#xff0c;如果内存不够…...

YOLOv8模型改进 第七讲 一种新颖的注意力机制 Outlook Attention

随着目标检测技术的不断发展&#xff0c;YOLOv8 作为最新一代的目标检测模型&#xff0c;已经在多个基准数据集上展现了其卓越的性能。然而&#xff0c;在复杂场景中&#xff0c;如何进一步提升模型的检测精度和鲁棒性依然是一个重要挑战。本文将探讨将 Outlook Attention 机制…...

C#多线程基本使用和探讨

线程是并发编程的基础概念之一。在现代应用程序中&#xff0c;我们通常需要执行多个任务并行处理&#xff0c;以提高性能。C# 提供了多种并发编程工具&#xff0c;如Thread、Task、异步编程和Parallel等。 Thread 类 Thread 类是最基本的线程实现方法。使用Thread类&#xff0…...

PHP DateTime基础用法

PHP DateTime 的用法详解 一、引言 在开发 PHP 应用程序时&#xff0c;处理日期和时间是一个至关重要的任务。PHP 提供了强大的日期和时间处理功能&#xff0c;其中 DateTime 类是最常用的工具之一。DateTime 类提供了丰富的方法来创建、格式化、计算和比较日期时间&#xff…...

一次Fegin CPU占用过高导致的事故

记录一下 一次应用事故分析、排查、处理 背景介绍 9号上午收到CPU告警&#xff0c;同时业务反馈依赖该服务的上游服务接口响应耗时太长 应用告警-CPU使用率 告警变更 【WARNING】项目XXX,集群qd-aliyun,分区bbbb-prod,应用customer,实例customer-6fb6448688-m47jz, POD实例CP…...

【Go初阶】两万字快速入门Go语言

初见golang语法 package mainimport "fmt"func main() {/* 简单的程序 万能的hello world */fmt.Println("Hello Go")} 第一行代码package main定义了包名。你必须在源文件中非注释的第一行指明这个文件属于哪个包&#xff0c;如&#xff1a;package main…...

【React】使用 react hooks 需要遵守的原则

1&#xff09;只能在顶层调用Hooks 这是指你不能在循环、条件语句或嵌套函数中调用Hooks。确保每次组件渲染时&#xff0c;Hooks的调用顺序保持一致。因此&#xff0c;你应该始终在React函数组件的最顶层调用Hooks。 React依赖于Hooks的调用顺序。如果这些调用在不同的渲染中顺…...

Python编程:创意爱心表白代码集

在寻找一种特别的方式来表达你的爱意吗&#xff1f;使用Python编程&#xff0c;你可以创造出独一无二的爱心图案&#xff0c;为你的表白增添一份特别的浪漫。这里为你精选了六种不同风格的爱心表白代码&#xff0c;让你的创意和情感通过代码展现出来。 话不多说&#xff0c;咱…...

腾讯IM SDK:TUIKit发送多张图片

一、问题描述 在使用腾讯IM DEMO&#xff08;https://github.com/TencentCloud/chat-uikit-vue.git&#xff09;时发现其只支持发送一张图片&#xff1a; 二、解决方案 // src\TUIKit\components\TUIChat\message-input-toolbar\image-upload\index.vue<inputref"inp…...

《本地部署开源大模型》在Ubuntu 22.04系统下ChatGLM3-6B高效微调实战

在Ubuntu 22.04系统下ChatGLM3-6B高效微调实战 无论是在单机单卡&#xff08;一台机器上只有一块GPU&#xff09;还是单机多卡&#xff08;一台机器上有多块GPU&#xff09;的硬件配置上启动ChatGLM3-6B模型&#xff0c;其前置环境配置和项目文件是相同的。如果大家对配置过程还…...

Python 脚本来自动发送每日电子邮件报告

安装必要的库 我们将使用 smtplib 发送邮件&#xff0c;以及 email.mime 来创建电子邮件内容。另外&#xff0c;为了让脚本自动定时运行&#xff0c;可以使用操作系统的计划任务工具&#xff08;如 Linux 的 cron 或 Windows 的 Task Scheduler&#xff09;。 创建邮件内容 使…...

大语言模型与ChatGPT:深入探索与应用

文章目录 1. 前言2. 大语言模型的概述2.1 什么是大语言模型&#xff1f;2.2 Transformer架构的核心2.3 预训练与微调 3. ChatGPT的架构与技术背景3.1 GPT模型的演进3.2 ChatGPT的工作原理 4. ChatGPT的实际应用4.1 日常对话助手4.2 内容生成与写作4.3 编程辅助4.4 教育与学习辅…...

【从零开始的LeetCode-算法】3164.优质数对的总数 II

给你两个整数数组 nums1 和 nums2&#xff0c;长度分别为 n 和 m。同时给你一个正整数 k。 如果 nums1[i] 可以被 nums2[j] * k 整除&#xff0c;则称数对 (i, j) 为 优质数对&#xff08;0 < i < n - 1, 0 < j < m - 1&#xff09;。 返回 优质数对 的总数。 示…...

FastDFS VS MinIO:文件存储与对象存储的抉择(包含SpringBoot集成FastDFS范例)

FastDFS vs MinIO&#xff1a;文件存储与对象存储的抉择&#xff08;包含SpringBoot集成FastDFS范例&#xff09; 我坐在窗边&#xff0c;随着飞机穿过云层&#xff0c;在云层之上滑翔。可以清晰的看到飞机在天空留下的痕迹&#xff0c;不知道那是蔚蓝中的纯白&#xff0c;还是…...