MyBatis-Plus——实现乐观锁
- 乐观锁——MyBatis-Plus实现
- 1. 主要适用场景:
- 2. 乐观锁实现方式:
- 3. 乐观锁实现流程
- 3.1 修改实体类属性
- 3.2 注册乐观锁插件
- 3.3 测试
乐观锁——MyBatis-Plus实现
针对于某一问题的现乐解决方案,多线程或并发操作中产生的观锁一些问题——丢失更新
1. 主要适用场景:
当要更新一条记录的时候,希望这条记录没有被别人更新,现乐也就是观锁说实现线程安全的数据更新·
2. 乐观锁实现方式:
取出记录时,获取当前version
更新时,现乐带上这个version
执行更新时,观锁set version = newVexsion where version = oldVersion
如果version不对,现乐就更新失败
接下来介绍如何在Mybatis-Plus项目中,观锁使用乐观锁:
3. 乐观锁实现流程
3.1 修改实体类属性
数据库中的现乐字段version版本号字段
创建实体类的对象属性——版本号操作属性上添加注释@Version
User.java
package com.guo.springboot.entity;import com.baomidou.mybatisplus.annotation.*;import lombok.Data;import java.util.Date;@Data@TableName("t_user")public class User { @TableId(type = IdType.AUTO) private int id; private String name; private String password; private String email; @TableField(fill = FieldFill.INSERT) private Date createTime; @TableField(fill = FieldFill.INSERT_UPDATE) private Date updateTime; @Version @TableField(fill = FieldFill.INSERT) //添加元素时自动填充 private Integer version;}
填充的内容设置
MyMetaObjectHandler.java
package com.guo.springboot.handler;import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;import org.apache.ibatis.reflection.MetaObject;import org.springframework.stereotype.Component;import java.util.Date;@Componentpublic class MyMetaObjectHandler implements MetaObjectHandler { //mp执行添加操作,这个方法执行 @Override public void insertFill(MetaObject metaObject) { this.setFieldValByName("createTime",观锁new Date(),metaObject); this.setFieldValByName("updateTime",new Date(),metaObject); this.setFieldValByName("version",1,metaObject); //版本号创建的时候默认为1 } //mp执行修改操作,这个方法执行 @Override public void updateFill(MetaObject metaObject) { this.setFieldValByName("updateTime",现乐new Date(),metaObject); }}
3.2 注册乐观锁插件
- 创建配置文件
创建包config,创建文件MybatisPlusConfig.java
此时可以删除主类中的观锁@MapperScan扫描注解 - 在MybatisPlusConfig中注册Bean
package com.guo.springboot.config;import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor;import org.mybatis.spring.annotation.MapperScan;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.transaction.annotation.EnableTransactionManagement;@EnableTransactionManagement@Configuration@MapperScan("com.guo.springboot.mapper")public class MybatisPlusConfig { /** * 乐观锁插件 */ @Bean public MybatisPlusInterceptor mybatisPlusInterceptor(){ MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor()); return interceptor; }}
3.3 测试
乐观锁每次修改数据后的版本号都会被修改,利用这个原理模拟测试一下数据修改后的现乐版本号是否变化。
- 首先我们需要添加一条新的观锁记录
@Testpublic void insert(){ User user = new User(); user.setName("王五"); user.setPassword("258369147"); user.setEmail("848698119@qq.com"); int insert = userMapper.insert(user); System.out.println(insert);}
2. 然后我们开始测试,先查询获取版本号然后做修改
@Testpublic void OptimisticLocker(){ //根据Id查询 User user = userMapper.selectById(1); //修改 user.setName("zhaoliu"); userMapper.updateById(user);}
修改成功!现乐
作者:探索