MyBatis-Plus:简化 CRUD 操作的艺术

news2024/11/25 10:56:07

一、关于MyBatis-Plus

1.1 简介

MyBatis-Plus 是一个基于 MyBatis 的增强工具,它旨在简化 MyBatis 的使用,提高开发效率。

9e920e5e-2e5b-4031-b546-1088ec5fa2e3

image

关于Mybatis

简介

MyBatis 是一款流行的 Java 持久层框架,旨在简化 Java 应用程序与数据库之间的交互。与传统的 ORM(对象关系映射)框架不同,MyBatis 提供了更大的灵活性,允许开发者自定义 SQL 语句。

91619c90-d7c3-4bd6-964d-0303af8ff2da

发展

初始阶段 - iBatis

  • 2001年:iBatis 项目由 Clinton Begin 发起,最初是一个开源项目,主要用于密码软件的开发,后来演变成一个基于 Java 的持久层框架。
  • 2004年:Clinton Begin 将 iBatis 的名字和源代码捐赠给了 Apache 软件基金会(ASF),成为 Apache 孵化器中的一个项目。在此期间,iBatis 成为了一个成熟的框架,被广泛应用于各种 Java 应用程序中。

转型期 - 从 iBatis 到 MyBatis

  • 2010年6月:iBatis 项目的核心开发团队决定将项目从 ASF 迁移到 Google Code,并将项目名改为 MyBatis。这次迁移标志着 iBatis 项目的重生,并引入了一些新的特性和改进。
  • 2013年11月:随着 Google Code 的服务逐步关闭,MyBatis 项目迁移至 GitHub,继续其开发和维护。

现代化与持续发展

  • 自从迁移到 GitHub 后,MyBatis 社区继续活跃,项目得到了持续的更新和完善。MyBatis 通过提供更好的 API 设计、更丰富的功能以及更高的灵活性,成为了许多 Java 开发者的首选持久层解决方案。
  • MyBatis 的设计使其能够很好地与其他 Java 框架(如 Spring)集成,同时也支持多种数据库管理系统(DBMS),这使得它成为一个非常灵活的选择。

特点
  1. SQL 语句映射:MyBatis 允许开发者通过 XML 或注解方式定义 SQL 语句,并将这些 SQL 语句与 Java 方法进行映射。
  2. 灵活性:与 ORM 框架相比,MyBatis 提供了更高的 SQL 自定义能力,开发者可以手动编写复杂的 SQL 语句,以满足具体的业务需求。
  3. 支持多种数据库:MyBatis 支持多种关系型数据库,便于在不同的环境中使用。
  4. 对象关系映射:虽然 MyBatis 不像 Hibernate 那样全面支持 ORM,但它提供了基本的对象映射功能,可以将数据库表中的记录映射为 Java 对象。
  5. 动态 SQL:MyBatis 支持动态 SQL,可以根据条件生成不同的 SQL 语句,提高了查询的灵活性。
  6. 缓存机制:MyBatis 提供了一级和二级缓存,能够提高数据库访问的性能,减少重复的数据库操作。
  7. 事务管理:MyBatis 支持与 Spring 等框架集成,方便管理数据库事务。

1.2 发展

MyBatis-Plus(简称 MP)是在 MyBatis 的基础上进行功能增强和扩展的一个开源项目,旨在进一步简化基于 MyBatis 的数据访问层(DAO)开发。以下是 MyBatis-Plus 的主要发展历程:

  1. 2016 年初

    • MyBatis-Plus 项目初始创建,最初由 baomidou (苞米豆)团队发起,旨在解决 MyBatis 使用过程中的繁琐代码和重复性工作,提供更便捷的 CRUD 操作和通用的查询功能。MyBatis-Plus 的名称直接表明了它与 MyBatis 的关系,即在 MyBatis 的基础上做了增强,而不是替代或改变 MyBatis 的原有功能。
  2. 功能逐步扩展

    • 初始阶段,MyBatis-Plus 主要集中在通用 CRUD 方法的封装和简化,以及一些便捷的查询功能,比如条件构造器等。
  3. 2017 年

    • MyBatis-Plus 在社区的支持下,逐步增加了更多实用的功能模块,如代码生成器、分页插件、性能分析插件等,使得开发者能够更高效地进行开发工作。
  4. 2018 年

    • MyBatis-Plus 发布了一系列更新版本,加强了对 Lambda 表达式的支持,使得在条件构造时可以更加简洁和直观,同时提高了查询的类型安全性。
  5. 2019 年

    • MyBatis-Plus 继续扩展其功能,引入了更多的增强特性和插件,如全局拦截器、SQL 注入器等,进一步增强了其在复杂应用场景下的灵活性和扩展性。
  6. 2020 年以后

    • MyBatis-Plus 持续稳定更新,解决了社区反馈的 bug 和安全问题,同时继续优化和增强现有功能,保持与最新技术的兼容性和整合性。

1.3 特性

  1. 无侵入设计:MyBatis-Plus 对 MyBatis 的核心功能进行了增强,使用时不需要对原有的 MyBatis 代码做过多改动。
  2. CRUD 操作的简化:提供了通用 Mapper 和通用 Service,开发者只需继承相应的接口即可实现基本的 CRUD 操作,减少了重复代码。
  3. 条件构造器:MyBatis-Plus 提供了 Lambda 形式的条件构造器,便于进行复杂的查询条件构造,提高了代码的可读性和维护性。
  4. 分页插件:内置分页功能,开发者可以轻松实现数据的分页查询,无需手动编写 SQL。
  5. 性能分析:提供 SQL 性能分析功能,可以查看执行的 SQL 语句及其性能,便于优化。
  6. 代码生成器:内置代码生成器,可以根据数据库表自动生成对应的实体类、Mapper 接口等,进一步提高开发效率。
  7. 多种扩展功能:支持乐观锁、逻辑删除、代码生成、注解驱动等功能,增强了应用的灵活性。

1.4 支持数据库

image

二、架构原理

image

2.1 核心组件

  1. AutoMapper:这是 MyBatis-Plus 中一个重要的抽象,它负责自动生成 CRUD 操作的 SQL 语句。开发者可以通过继承 BaseMapper<T>​ 接口来实现自己的 Mapper 接口。
  2. ServiceImpl:这是 MyBatis-Plus 提供的服务实现类,它继承自 ServiceImpl<T, IId>​,为 Service 层提供了一系列常用的方法。
  3. Entity:这是 MyBatis-Plus 中用于表示数据库表的实体类,通常继承自 BaseEntity​,以便利用一些通用属性和方法。
  4. Configuration:配置 MyBatis-Plus 的各种行为,如分页、日志记录等。
  5. Interceptor:拦截器,可以用来拦截 SQL 语句,例如分页插件、性能分析插件等。

2.2 主要模块

  1. CRUD 操作:提供了诸如 insert()​, updateById()​, deleteById()​ 等方法,简化了 CRUD 操作。
  2. Lambda 表达式:允许使用 Java 8 的 Lambda 表达式来构建查询条件,提高了代码的可读性和安全性。
  3. 分页插件:内置的分页功能,通过简单的配置即可启用。
  4. 代码生成器:提供了一个命令行工具,可以快速生成基础的 Mapper、Model、Service、Controller 层代码。
  5. 全局拦截器:可以全局拦截 SQL 语句,进行一些额外的操作,比如记录日志、SQL 分析等。

2.3 工作原理

初始化阶段

  1. SqlSessionFactoryBuilder:MyBatis-Plus 使用 MyBatis 的 SqlSessionFactoryBuilder​ 来构建 SqlSessionFactory​,这是 MyBatis-Plus 应用程序启动的第一步。
  2. SqlSessionFactorySqlSessionFactory​ 创建 SqlSession​,SqlSession​ 负责执行 SQL 语句,并将结果映射到 Java 对象。
  3. Configuration:配置文件被解析,配置 MyBatis-Plus 的各种行为,如分页插件的配置等。

执行阶段

  1. Mapper 接口调用:开发者通过调用 Mapper 接口中定义的方法来触发 SQL 操作。
  2. SQL 语句生成:根据传入的参数,MyBatis-Plus 自动生成相应的 SQL 语句。例如,使用 lambdaQuery()​ 方法可以生成带有条件的 SQL。
  3. SQL 执行:SQL 语句通过 SqlSession​ 执行,结果被映射到对应的 Java 对象。
  4. 结果返回:执行结果被封装后返回给调用方。

特殊功能实现

  1. 分页功能:通过全局拦截器自动添加分页信息到 SQL 语句中,实现分页查询。
  2. 性能分析:同样通过全局拦截器记录 SQL 执行时间和慢查询,帮助优化数据库访问。
  3. Lambda 表达式支持:利用 Java 8 的 Lambda 表达式来构建查询条件,提高了代码的可读性和可维护性。

MyBatis-Plus 通过一系列的设计模式和插件机制,极大地简化了基于 MyBatis 的应用程序开发。它通过自动化的 CRUD 操作、Lambda 表达式支持、内置分页插件等功能,降低了开发者的负担,并提高了开发效率。同时,它还提供了代码生成器,进一步加快了开发速度。这些特性使得 MyBatis-Plus 成为一个非常受欢迎的 MyBatis 扩展工具。

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

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

相关文章

ECharts饼图-圆角环形图,附视频讲解与代码下载

引言&#xff1a; 在数据可视化的世界里&#xff0c;ECharts凭借其丰富的图表类型和强大的配置能力&#xff0c;成为了众多开发者的首选。今天&#xff0c;我将带大家一起实现一个饼图图表&#xff0c;通过该图表我们可以直观地展示和分析数据。此外&#xff0c;我还将提供详…

正则表达式匹配日期格式

前言 这里有sql文本&#xff0c;是从数据库中拷贝出来的&#xff0c;希望重新执行的时候createTime和updateTime都统一设置成当前日期。 利用正则表达式结合文本编辑器&#xff0c;就能全局替换了 (\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}) 替换结果如下

学习伊圣雨老师的 epoll 编程

&#xff08;1&#xff09;书里提出了疑问&#xff0c;epoll 函数的工作方式&#xff0c;区分为水平触发与边缘触发 &#xff1a; &#xff08;2&#xff09; 谢谢

3.2K+ Star!OpenLLMetry:一个开源的LLM应用可观测性工具

OpenLLMetry 简介 OpenLLMetry[1] 是一个基于OpenTelemetry的开源可观测性工具&#xff0c;专为LLM&#xff08;Large Language Models&#xff0c;大型语言模型&#xff09;应用设计。 它提供了一套扩展&#xff0c;可以帮助开发者全面监控和管理他们的LLM应用。 项目特点 主…

C# 编程语言学习教程

C# 编程语言学习教程 目录 C# 简介 1.1 什么是 C#1.2 C# 的特点1.3 C# 的应用领域 环境搭建 2.1 安装 Visual Studio2.2 创建第一个 C# 项目 基础语法 3.1 数据类型3.2 控制结构3.3 数组与字符串 面向对象编程 4.1 类与对象4.2 继承与多态4.3 接口与抽象类 常用库与框架 5.1 .…

分类预测 | GCN图卷积神经网络多特征分类预测(MATLAB)

分类预测 | GCN图卷积神经网络多特征分类预测(MATLAB) 目录 分类预测 | GCN图卷积神经网络多特征分类预测(MATLAB)分类效果基本介绍程序设计参考资料分类效果 基本介绍 GCN图卷积神经网络多特征分类预测(MATLAB) 在图卷积神经网络(GCN)中,多特征分类

以AI赋能身份验证,Jumio助力中国企业出海

近年来&#xff0c;越来越多的中国企业开始扬帆出海积极拓展全球市场。而能够为企业出海提供各种助力的技术与解决方案&#xff0c;也成为了众多企业关注的焦点。 作为全球领先的在线身份验证和欺诈预防解决方案提供商&#xff0c;Jumio于近日在北京举办了中国媒体见面会&#…

中级 <HarmonyOS第一课>合理使用动画和转场的课后习题

天道无亲&#xff0c;常与善人。 天命人&#xff0c;战斗吧&#xff01;&#xff01;&#xff01; 来自 <HarmonyOS第一课>合理使用动画和转场的习题。 判断题 animateTo可以设置组件进行位移动画时的运动路径。❌ 单选题 模态转场不包括以下哪个类别&#xff1f; A. …

Python(包和模块)

包 定义 包是将模块以文件夹的组织形式进行分组管理的方法&#xff0c;以便更好地组织和管理相关模块。 包是一个包含一个特殊的__init__.py文件的目录&#xff0c;这个文件可以为空&#xff0c;但必须存在&#xff0c;以标识目录为Python包。 包可以包含子包&#xff08;子…

数据采集-Kepware OPCUA 服务器实现

KepserverEX OPC UA server设置 目录 KepserverEX OPC UA server设置一、OPC UA(OPC Unified Architecture)二、防火墙的配置三、配置KepserverEX的OPC UA3.1 启用远程连接3.2 启动OPCUA服务器接口 四、管理OPCUA的端口和证书4.1 添加端口4.2 证书申请 一、OPC UA(OPC Unified …

医学和生信web APP 平台- Appmatrix

医学&#xff08;和生信&#xff09;web APP 平台- Appmatrix 最近使用shinyproxy将平时所构建的shiny和streamlit医学类应用汇集在一起&#xff0c;实现一站式访问&#xff0c;另外&#xff0c;使用了自己电脑内网穿透&#xff0c;一定程度上缓解了数据分析类APP消耗计算资源…

PyTorch nn.Conv2d 空洞卷积

torch.nn.Conv2d() 中 dilation 参数控制卷积核的间隔 dilation controls the spacing between the kernel points 当 dilation1 时, 表示卷积核没有额外的空白间距, 也就是标准卷积当 dilation>1 时, 表示空洞卷积(dilated convolution) 动画演示: 手动计算 以 2*2 的卷…

大模型,多模态大模型面试问题【计算图,LLama,交叉熵,SiLU,RLHF】

大模型&#xff0c;多模态大模型面试问题【计算图&#xff0c;LLama&#xff0c;交叉熵&#xff0c;SiLU&#xff0c;RLHF】 问题一&#xff1a;讲一讲计算图中pytorch是什么&#xff0c;TensorFlow是什么&#xff1f;1. PyTorch2. TensorFlow区别总结 问题二&#xff1a;Llama…

learnopencv系列一:使用神经网络进行特征匹配(LoFTR、XFeat、OmniGlue)、视频稳定化、构建Chrome Dino游戏机器人

文章目录 一、使用神经网络进行特征匹配1.1 什么是图像特征&#xff1f;1.2 特征匹配的应用场景——为什么在2024年还要进行特征匹配&#xff1f;1.3 特征匹配——经典方法与深度学习1.3.1 经典特征匹配1.3.2 深度学习特征匹配1.3.3 XFeat1.3.3.1 网络结构1.3.3.2 局部特征提取…

MySQL 数据出海之数据同步方案

优质博文&#xff1a;IT-BLOG-CN 数据库出海流程 【1】业务出海&#xff1a;1&#xff09;数据库出海&#xff1b;2&#xff09;应用出海&#xff1b;3&#xff09;流量分发&#xff1b; 【2】数据库出海&#xff1a;涉及业务方、信安、DBA和框架组。 数据库出海&#xff0c…

Elasticsearch 安装教程:驾驭数据海洋的星际导航仪

目录 一、准备工作1. ES的下载 二、安装步骤三、注意事项四、启动报错1. org.elasticsearch.bootstrap.StartupException: java.lang.RuntimeException: can not run elasticsearch as root2. max virtual memory areas vm.max_map_count [65530] is too low, increase to at l…

RK3568平台开发系列讲解(I2C篇)I2C 上拉电阻

🚀返回专栏总目录 文章目录 一、接上拉电阻的作用二、I2C 上拉电阻阻值计算沉淀、分享、成长,让自己和他人都能有所收获!😄 I2C 的硬件连接如下图所示: 可以看到在 SDA 数据线和 SCL 时钟线上都需要接一个上拉电阻? 一、接上拉电阻的作用 SDA 数据线和 SCL 时钟线上接…

使用AIM对SAP PO核心指标的自动化巡检监控

一、背景 由于SAP PO系统维护成本较高&#xff0c;各类型异常报错等都需要人员进行时刻监控和响应&#xff0c;遂由AIM平台进行自动化巡检SAP PO的各指标&#xff0c;然后告警通知用户&#xff0c;节省维护成本和提高工作效率 二、核心指标监控 SAP PO失败消息 适用于S…

Golang | Leetcode Golang题解之第521题最长特殊序列I

题目&#xff1a; 题解&#xff1a; func findLUSlength(a, b string) int {if a ! b {return max(len(a), len(b))}return -1 }func max(a, b int) int {if b > a {return b}return a }

C语言:动态内存管理【上】

一. malloc C语言提供了一个动态内存开辟的函数&#xff1a; 1 void* malloc (size_t size);这个函数向内存申请一块连续可用的空间&#xff0c;并返回指向这块空间的指针。 &#xff0e;如果开辟成功&#xff0c;则返回一个指向开辟好空间的指针。 &#xff0e;如果开辟失败…