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

SpringBoot + Mybatis-Plus中乐观锁实现

  • 悲观锁

    悲观锁是一种悲观思想,它认为数据很可能会被别人所修改

    所以总会对数据进行上锁,读操作和写操作都会上锁,性能较低,使用较少!

  • 乐观锁

    乐观锁是一种乐观思想,它认为数据并不一定会被别人所修改

    所以读操作不会上锁,但写操作时会先判断当前数据是否被修改过(一般采用版本号机制来实现 )  

乐观锁的实现方式:

  • 在表中添加一个 version 字段,表示数据的版本

  • 修改数据时首先判断自己当前拥有的 version 和数据库中的 version 是否一致

  • 如果一致,则修改数据,同时将 version 加 1,表示数据版本发生了变化

  • 如果不一致,则修改失败,表示数据被别人修改过。

步骤:

  1. 在实体类的字段上加上@Version注解

    @Version // 乐观锁注解
    private Integer version;
  2. 配置MybatisPlusConfig

    @Configuration
    @MapperScan("net.wanho.mapper")
    public class MyBatisPlusConfig {/*** 拦截器*/@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();// 分页插件interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));// 乐观锁插件interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());return interceptor;}}
  3. 测试

    修改数据时执行的sql语句:UPDATE product SET name=?, price=?, version=? WHERE id=? AND version=?

    • 修改的条件中,对 version 做了判断,只有和当前拥有的 version 一致才进行修改

    • 修改的字段中,对 version 做了+1

  4. 判断是否修改失败

    如果修改失败,重新获取商品信息,再次修改

    if (result2 == 0) {// 5.小王修改失败,重新获取商品信息p2 = productMapper.selectById(1);// 6.小王将商品减了30元,存入了数据库p2.setPrice(p2.getPrice() - 30);result2 = productMapper.updateById(p2);System.out.println("小王修改结果:" + result2);
    }

http://www.lryc.cn/news/354233.html

相关文章:

  • 设计模式深度解析:分布式与中心化,IT界两大巨头“华山论剑”
  • 转行一年了
  • 【LeetCode 151】反转字符串中的单词
  • Behind the Code:Polkadot 如何重塑 Web3 未来
  • for循环里如果std::pair的类型写不对,可能会造成性能损失
  • 【Linux】Linux的基本指令_2
  • Effective C++(3)
  • 自定义RedisTemplate序列化器
  • Flutter 中的 CupertinoContextMenuAction 小部件:全面指南
  • Element-Ul快速入门
  • Django的模型层——2模型实例
  • Python筑基之旅-MySQL数据库(四)
  • OceanBase SQL 诊断和调优实践——【DBA从入门到实践】第七期
  • C++之std::is_trivially_copyable(平凡可复制类型检测)
  • 宝石收集,tarjan
  • python 面对对象 类 继承
  • Rust腐蚀怎么用服务器一键开服联机教程
  • 公共代理IP和独享代理IP之间的区别?
  • 基于Vue的前端自定义询问弹框与输入弹框组件的设计与实践
  • 淘宝订单系统ERP中如何接入平台订单信息?(订单API)
  • 在Spring Boot项目中集成和使用MQTT
  • 14、设计模式之访问者模式
  • Excel如何换行不换格
  • Elasticsearch 8.1官网文档梳理 - 十五、Aggregations(聚合)
  • 计算机系统概论
  • 【Vue】diff 算法
  • Spring Boot 3.x 与 Spring Boot 2.x 的对比
  • SSLError ClosedPoolError
  • 勒索软件分析_Conti
  • Linux系统如何通过编译方式安装python3.11.3