mp乐观锁
解决丢失更新问题(当要更新一条记录的时候,希望这条记录没有被别人更新)
丢失更新(多个人同时去修改同一条记录,最后提交的那个,会把之前提交的都给覆盖掉)
问题解决:悲观锁(串行):同一个东西,只能一个人同时操作
乐观锁:取出记录时,获取当前version(版本号)
更新时,带上这个version(更新完成后,版本号会变化)
执行更新时,set version=newVersion where version=oldVersion
如果version不对,就更新失败
1:在表里面加一个version(int型),意为版本号
2:对应实体类(User)添加版本号属性
在实体类版本号属性上添加注解
@Version
private Integer version;//版本号
3:配置乐观锁插件
一:如果是spring xml:添加这即可
<bean class="com.baomidou.mybatisplus.extension.plugins.OptimisticLockerInterceptor"/>
二:如果是spring boot:
把这个插件插入
@Bean //插件
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
注:在本子模块下,建立一个配置类(存放所有的配置):
先创建个包config(存储所有的配置类),再创建mp的配置类:MpConfig
添加一个@Configuration,再把配置放进去。再把启动类中的中的@MapperScan(“com.zpc.myplus02.mapper”)添加过来
注:只要是属于mp的配置,皆可放在这里
package com.zpc.myplus02.config;
//包省略
@Configuration
@MapperScan("com.zpc.myplus02.mapper") //以此来使主程序找到mapper这个接口
public class MpConfig {
//配置乐观锁插件
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
}