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

 更新时间:2024年10月17日 15:27:09   作者:Damon小智  
MyBatisPlus为MyBatis的增强版,专注于简化数据库操作,提供自动化CRUD、内置分页和乐观锁等功能,极大提升开发效率,在SpringCloud微服务架构中,MyBatisPlus通过插件机制和自动生成代码功能,有效支持企业级应用和分布式系统的开发

Java技术迷

在现代微服务架构中,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 的依赖:

1
2
3
4
5
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.4.3.4</version>
</dependency>

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

1
2
3
4
5
6
7
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/your_database?useSSL=false
    username: root
    password: your_password
  mybatis-plus:
    mapper-locations: classpath:/mapper/*.xml

2. 实体类的定义

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

1
2
3
4
5
6
7
8
9
@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。

1
2
public interface UserMapper extends BaseMapper<User> {
}

4. Service 层的实现

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

1
2
3
4
5
6
7
8
9
10
11
@Service
public class UserService {
    @Autowired
    private UserMapper userMapper;
    public List<User> getAllUsers() {
        return userMapper.selectList(null);
    }
    public void createUser(User user) {
        userMapper.insert(user);
    }
}

三、MyBatis Plus 的高级用法

1. 分页插件

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

1
2
3
4
5
6
@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 注解来启用乐观锁功能。

1
2
3
4
5
6
7
8
9
10
11
@Data
@TableName("user")
public class User {
    @TableId(type = IdType.AUTO)
    private Long id;
    private String name;
    private Integer age;
    private String email;
    @Version
    private Integer version; // 乐观锁版本字段
}

3. 多租户插件

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

1
2
3
4
5
6
7
8
9
10
11
@Configuration
public class MybatisPlusConfig {
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        // 多租户插件配置
        TenantLineInnerInterceptor tenantLineInnerInterceptor = new TenantLineInnerInterceptor();
        interceptor.addInnerInterceptor(tenantLineInnerInterceptor);
        return interceptor;
    }
}

4. 自动填充功能

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

1
2
3
4
5
6
7
8
9
10
11
12
13
@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 注解实现。

1
2
3
4
5
6
7
8
9
10
11
@Data
@TableName("user")
public class User {
    @TableId(type = IdType.AUTO)
    private Long id;
    private String name;
    private Integer age;
    private String email;
    @TableLogic
    private 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 的编写工作。

1
2
3
4
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的使用与原理详解的文章就介绍到这了,更多相关SpringCloud MyBatis Plus使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

蓄力AI

微信公众号搜索 “ 脚本之家 ” ,选择关注

程序猿的那些事、送书等活动等着你

原文链接:https://blog.csdn.net/weixin_41793160/article/details/142966313

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!

相关文章

  • SpringBoot JSON全局日期格式转换器实现方式

    SpringBoot JSON全局日期格式转换器实现方式

    这篇文章主要介绍了SpringBoot JSON全局日期格式转换器,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • 使用IDEA和Gradle构建Vertx项目(图文步骤)

    使用IDEA和Gradle构建Vertx项目(图文步骤)

    这篇文章主要介绍了使用IDEA和Gradle构建Vertx项目(图文步骤),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • 在service层注入mapper时报空指针的解决

    在service层注入mapper时报空指针的解决

    这篇文章主要介绍了在service层注入mapper时报空指针的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • feign调用第三方接口,编码定义GBK,响应中文乱码处理方式

    feign调用第三方接口,编码定义GBK,响应中文乱码处理方式

    这篇文章主要介绍了feign调用第三方接口,编码定义GBK,响应中文乱码处理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • 详解Spring Boot中整合Sharding-JDBC读写分离示例

    详解Spring Boot中整合Sharding-JDBC读写分离示例

    这篇文章主要介绍了详解Spring Boot中整合Sharding-JDBC读写分离示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-03-03
  • Java中泛型通配符的使用方法示例

    Java中泛型通配符的使用方法示例

    这篇文章主要介绍了Java中泛型通配符的使用方法,结合实例形式分析了java中泛型通配符的功能、语法及在泛型类创建泛型对象中的使用方法,需要的朋友可以参考下
    2019-08-08
  • IDEA不编译除了.java之外的文件的解决办法(推荐)

    IDEA不编译除了.java之外的文件的解决办法(推荐)

    这篇文章主要介绍了IDEA不编译除了.java之外的文件的解决办法,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • java递归法求字符串逆序

    java递归法求字符串逆序

    这篇文章主要介绍了java递归法求字符串逆序,涉及java递归调用的相关操作技巧,需要的朋友可以参考下
    2015-05-05
  • SpringBoot使用Captcha生成验证码

    SpringBoot使用Captcha生成验证码

    这篇文章主要介绍了SpringBoot如何使用Captcha生成验证码,帮助大家更好的理解和学习使用SpringBoot,感兴趣的朋友可以了解下
    2021-04-04
  • Java基础知识之Java语言概述

    Java基础知识之Java语言概述

    这篇文章主要介绍了Java基础知识之Java语言概述,本文介绍了Java语言相关的基础知识、历史介绍、主要应用方向等内容,需要的朋友可以参考下
    2015-03-03

最新评论