網站首頁 編程語言 正文
1:首先在實體類的屬性注解上使用@Version
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.annotation.Version;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;
import java.util.Date;
/**
* @Description: 訪客數據
* @Author: xqf
* @Date: 2023-07-27
* @Version: V1.0
*/
@Data
@TableName("sys_visitant_data")
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@ApiModel(value="sys_visitant_data對象", description="訪客數據")
public class SysVisitantData {
/**id*/
@TableId(type = IdType.ASSIGN_ID)
@ApiModelProperty(value = "id")
private String id;
/**訪客openId*/
@Excel(name = "訪客openId", width = 15)
@ApiModelProperty(value = "訪客openId")
private String visitantOpenId;
@Version
private Long version;
}
2:在數據庫表中添加version字段,注意實體類使用是long和int類型(和默認值為0)
3:在mybatis-plus攔截器中添加OptimisticLockerInnerInterceptor()樂觀鎖攔截器
@Configuration
@MapperScan(value={"org.demo.modules.**.mapper*"})
public class MybatisConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor(){
MybatisPlusInterceptor interceptor= new MybatisPlusInterceptor();
//添加分頁攔截器
interceptor.addInnerInterceptor(new PaginationInnerInterceptor());
//添加樂觀鎖攔截器
interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
return interceptor;
}
}
4:demo(version字段版本會自動每次加一操作)
@PostMapping("/apply2")
public Result<?> apply2() {
SysVisitantData visitantData = sysVisitantDataService.getById("1724065295435689986");
Integer visitantNumber = visitantData.getVisitantNumber();
System.out.println("開始#2:" + visitantNumber);
visitantData.setVisitantNumber(visitantNumber + 5);
boolean flag = sysVisitantDataService.updateById(visitantData);
if (!flag){
throw new JeecgBootException("2保存失敗");
}
System.out.println("更新#2:" + visitantData.getVisitantNumber());
return Result.OK();
}
原文鏈接:https://blog.csdn.net/qq_19891197/article/details/134430159
- 上一篇:沒有了
- 下一篇:沒有了
相關推薦
- 2022-06-13 Docker?registry私有鏡像倉庫服務部署案例演示_docker
- 2022-10-12 go實現限流功能示例_Golang
- 2022-09-04 關于Python下的Matlab函數對應關系(Numpy)_python
- 2022-03-20 Oracle進階DECODE函數使用詳解_oracle
- 2022-07-06 Flutter?DateTime日期轉換的詳細使用_Android
- 2021-12-01 C語言system函數使用方法詳解_C 語言
- 2022-10-27 SQL案例學習之字符串的合并與拆分方法總結_oracle
- 2023-05-06 react中axios結合后端實現GET和POST請求方式_React
- 欄目分類
-
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支