【Spring Boot 快速入门】十八、Spring Boot 集成Mybatis_Plus的乐观锁

简介: 【Spring Boot 快速入门】十八、Spring Boot 集成Mybatis_Plus的乐观锁

前言


  在操作关系数据库管理系统里,经常会遇到锁的问题,在数据库中有行锁、页锁和表锁。在Java的开发过程中,经常会遇到悲观锁和乐观锁。乐观锁和悲观锁对于理解Java多线程、并发和数据库来说至关重要。下面和大家已起聊聊关于Mybatis_Plus乐观锁。


数据库锁


  锁是数据库中的一个重要的概念,在大数据高并发的情况下,如果同一条数据被多个线程读取,可能会出现幻读、脏读、误读的情况。所以引入了锁。在程序员操作方面,可以根据锁的使用分类悲观锁和乐观锁。

  悲观锁总是认为最坏的情况会出现,当前的数据可能被修改,从而在读取数据的时候就会把资源或者数据进行锁定,其他线程使用这个数据或者资源的时候就会阻塞等待,直到悲观锁将锁释放之后,其他资源才可以使用。

  乐观锁与悲观锁正好相反,乐观锁总是认为资源和数据不会被修改,在读取数据和资源时不会进行加锁。但是乐观锁是在写入操作的时候会判断当前数据和资源是否修改过。乐观锁的实现方案一般来说有两种: 版本号机制 和 CAS实现 。

  在我们的项目中,使用Mybatis_Plus敏捷开发,近期学习了一下基于Mybatis_Plus的乐观锁,下面快速开始熟悉吧。


快速开始


版本介绍


  本次将基于Spring Boot 搭建一个学习Mybatis_Plus的乐观锁的Demo。开发环境如下:


JDK1.8
SpringBoot 2.3.0.RELEASE
mybatis-plus 3.3.0

  

Mybatis_Plus的乐观锁的实现原理是基于版本号机制进行控制的。当在取出一条数据后,将对该条数据进行更新修改操作,会获取当前数据的version版本号,在更新时带上version版本号信息,执行更新时,会判断当前的version版本号与数据库中的版本号是否一致,一致则更新成功version版本号+1,如果version版本号信息不一致,则证明数据被修改过,更新数据失败。了解了原理,下面快速开始。


引入依赖


本次学习使用的依赖包如下:


<dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.3.0</version>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.3.0</version>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-extension</artifactId>
            <version>3.4.0</version>
        </dependency>


配置乐观锁


在项目中配置乐观锁的拦截器信息如下:


@Component
public class MybatisPlusConfig {
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
        return interceptor;
    }
}


指定版本号


  在我们数据库的实体对象中指定一个版本号字段,并用注解@Version注释该字段。@Version注释的字段类型支持:int,Integer,long,Long,Date,Timestamp,LocalDateTime,在整数类型下newVersion = oldVersion + 1会自动递增版本号,需要注意的是仅支持updateById()和update(entity, wrapper)方法。 本次建立一个User对象。

@ApiModel(value = "com-example-demo-module-User")
@TableName("user")
public class User {
    @TableId(value = "id", type = IdType.INPUT)
    private Integer id;
    @TableField(value = "name")
    private String name;
    @TableField(value = "age")
    private int age;
    @Version
    private int version;
}


单元测试


编写完如上基本配置之后,就可以进行简单的单元测试了。首先我们创建一个用户信息。

@Test
    void TestUser(){
        User user = new User();
        user.setName("测试1");
        user.setAge(12);
        userMapper.insert(user);
    }


可以看到用户“测试1”已经新增成功,当前的用户id是19。


image.png

编写单元测试二,本次更新2次id为19的用户信息。


@Test
    void TestUser(){
        User user = userService.getById(19);
        System.out.println(user);
        //开始更新一次
        userService.updateByTest(user);
        user.setName("测试32222");
        userService.updateById(user);
        User user1 = userService.getById(user.getId());
        System.out.println("第二个更新的方法:" +user1);
    }


运行结果如下,可以看到版本号已经进行了自动更新:

image.png

User{id=19, name='测试32222', age=12, version=0}
第一个更新的方法:User{id=19, name='123456', age=12, version=1}
第二个更新的方法:User{id=19, name='测试32222', age=12, version=2}


结语


  好了,以上就是Spring Boot 集成Mybatis_Plus的乐观锁


目录
相关文章
|
4月前
|
JSON 分布式计算 大数据
springboot项目集成大数据第三方dolphinscheduler调度器
springboot项目集成大数据第三方dolphinscheduler调度器
247 3
|
5月前
|
Java 数据库连接 数据库
Spring boot 使用mybatis generator 自动生成代码插件
本文介绍了在Spring Boot项目中使用MyBatis Generator插件自动生成代码的详细步骤。首先创建一个新的Spring Boot项目,接着引入MyBatis Generator插件并配置`pom.xml`文件。然后删除默认的`application.properties`文件,创建`application.yml`进行相关配置,如设置Mapper路径和实体类包名。重点在于配置`generatorConfig.xml`文件,包括数据库驱动、连接信息、生成模型、映射文件及DAO的包名和位置。最后通过IDE配置运行插件生成代码,并在主类添加`@MapperScan`注解完成整合
935 1
Spring boot 使用mybatis generator 自动生成代码插件
|
4月前
|
缓存 JSON 前端开发
第07课:Spring Boot集成Thymeleaf模板引擎
第07课:Spring Boot集成Thymeleaf模板引擎
503 0
第07课:Spring Boot集成Thymeleaf模板引擎
|
4月前
|
Java 关系型数据库 MySQL
springboot项目集成dolphinscheduler调度器 实现datax数据同步任务
springboot项目集成dolphinscheduler调度器 实现datax数据同步任务
514 2
|
4月前
|
分布式计算 Java 大数据
springboot项目集成dolphinscheduler调度器 可拖拽spark任务管理
springboot项目集成dolphinscheduler调度器 可拖拽spark任务管理
277 2
|
5月前
|
Java 数据库连接 API
Java 对象模型现代化实践 基于 Spring Boot 与 MyBatis Plus 的实现方案深度解析
本文介绍了基于Spring Boot与MyBatis-Plus的Java对象模型现代化实践方案。采用Spring Boot 3.1.2作为基础框架,结合MyBatis-Plus 3.5.3.1进行数据访问层实现,使用Lombok简化PO对象,MapStruct处理对象转换。文章详细讲解了数据库设计、PO对象实现、DAO层构建、业务逻辑封装以及DTO/VO转换等核心环节,提供了一个完整的现代化Java对象模型实现案例。通过分层设计和对象转换,实现了业务逻辑与数据访问的解耦,提高了代码的可维护性和扩展性。
218 1
|
分布式计算 大数据 Java
springboot项目集成大数据第三方dolphinscheduler调度器 执行/停止任务
springboot项目集成大数据第三方dolphinscheduler调度器 执行/停止任务
78 0
|
4月前
|
SQL Java 数据库连接
Spring、SpringMVC 与 MyBatis 核心知识点解析
我梳理的这些内容,涵盖了 Spring、SpringMVC 和 MyBatis 的核心知识点。 在 Spring 中,我了解到 IOC 是控制反转,把对象控制权交容器;DI 是依赖注入,有三种实现方式。Bean 有五种作用域,单例 bean 的线程安全问题及自动装配方式也清晰了。事务基于数据库和 AOP,有失效场景和七种传播行为。AOP 是面向切面编程,动态代理有 JDK 和 CGLIB 两种。 SpringMVC 的 11 步执行流程我烂熟于心,还有那些常用注解的用法。 MyBatis 里,#{} 和 ${} 的区别很关键,获取主键、处理字段与属性名不匹配的方法也掌握了。多表查询、动态
150 0
|
4月前
|
存储 人工智能 Java
Springboot集成AI Springboot3 集成阿里云百炼大模型CosyVoice2 实现Ai克隆语音(未持久化存储)
本项目基于Spring Boot 3.5.3与Java 17,集成阿里云百炼大模型CosyVoice2实现音色克隆与语音合成。内容涵盖项目搭建、音色创建、音频合成、音色管理等功能,适用于希望快速掌握Spring Boot集成语音AI技术的开发者。需提前注册阿里云并获取API Key。