亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringBoot+MyBatisPlus中樂觀鎖的實現(xiàn)示例

 更新時間:2023年08月22日 15:42:22   作者:weixin_43652507  
樂觀鎖是一種用于解決并發(fā)沖突的機制,在數(shù)據(jù)庫中用于保護數(shù)據(jù)的一致性,本文主要介紹了SpringBoot+MyBatisPlus中樂觀鎖的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下

樂觀鎖加注解@Version后不需要手動進行加1操作。樂觀鎖是一種用于解決并發(fā)沖突的機制,在數(shù)據(jù)庫中用于保護數(shù)據(jù)的一致性。@Version注解是MyBatisPlus框架中的樂觀鎖注解,它會在更新數(shù)據(jù)時自動檢查版本號是否一致,如果一致則進行更新操作,如果不一致則表示數(shù)據(jù)已被其他線程修改過,更新操作會失敗。

@Version注解會自動對版本號進行加1操作,所以在使用樂觀鎖時不需要手動進行加1操作。當進行更新操作時,MyBatisPlus會自動更新版本號,并將更新后的版本號與更新條件一起發(fā)送給數(shù)據(jù)庫,如果版本號在更新過程中發(fā)生變化,則說明數(shù)據(jù)已被其他線程修改,更新操作會失敗。

因此,使用樂觀鎖加注解@Version后,可以簡化代碼,并且可以保證數(shù)據(jù)的一致性

使用場景: 當要更新一條數(shù)據(jù)時,希望這條數(shù)據(jù)沒有被別人更新,也就是說實現(xiàn)線程安全的數(shù)據(jù)更新

1. 數(shù)據(jù)庫新增version字段, int類型, 默認值為0

2. 引入依賴

<!--MyBatisPlus 攔截器-->
<dependency>
	<groupId>com.baomidou</groupId>
	<artifactId>mybatis-plus-boot-starter</artifactId>
	<version>3.5.1</version>
</dependency>

3. springboot啟動類中新增bean

     /**
     * 支持攔截器樂觀鎖
     *
     * @return
     */
    @Bean
    public MybatisPlusInterceptor optimisticLockerInterceptor(){
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
        return interceptor;
    }

4. 實體類 version字段貼上注解 &#64;Version

@Version
private Long version;

5. sql更新語句 (&#64;Version注解會自動對版本號進行加1操作&#xff0c;所以在使用樂觀鎖時不需要手動進行加1操作)

// 沒加@Version注解sql
update wx_dept set name=#{name}, sn=#{sn}, version=#{version}+1 where id=#{id} and version=#{version}
// 加了@Version注解sql
update wx_dept set name=#{name}, sn=#{sn}, version=#{version} where id=#{id} and version=#{version}

6. service (樂觀鎖操作步驟: 每次操作前都是先查詢、替換、最后更新, 否則樂觀鎖無效)

    /**
     * 修改部門
     * 
     * @param wxDept 部門
     * @return 結果
     */
    @Override
    public AjaxResult updateWxDept(WxDept wxDept) {
        // 樂觀鎖操作步驟: 每次操作前都是先查詢、替換、最后更新, 否則樂觀鎖無效
        // 1. 先查詢
        WxDept dept = wxDeptMapper.selectWxDeptById(wxDept.getId());
        log.info("查詢出來的數(shù)據(jù): {}", dept);
        // 2. 替換
        dept.setName("小賣鋪");
        dept.setSn("sell");
        // 3. 最后更新
        int i = wxDeptMapper.updateWxDept(dept);
        if (i > 0) {
            return AjaxResult.success("樂觀鎖更新成功");
        } else {
            return AjaxResult.error("樂觀鎖更新失敗");
        }
    }

7. 測試

7.1 查詢出id是1的數(shù)據(jù), 并修改數(shù)據(jù) name&#61;小賣鋪, sn&#61;sell

查詢出來的數(shù)據(jù): com.ruoyi.ruoyiwx.dept.domain.WxDept@861f795[
  id=1
  name=開發(fā)部
  sn=dev
  version=0
]

7.2 假設

7.1還沒更新時, 就有其它線程修改了id為1的數(shù)據(jù), 版本號version&#61;1

7.3 上面7.1執(zhí)行update更新時就會失敗, 因為版本號version&#61;1, 不是剛查詢出來的version&#61;0

{
    "msg": "樂觀鎖更新失敗",
    "code": 500
}

總結:

1. 每次去拿數(shù)據(jù)的時候都會認為別人不會修改數(shù)據(jù), 所以不會上鎖

2. 但是在更新的時候會判斷在此期間有沒有人去更新過這個數(shù)據(jù), 可以使用版本號version

到此這篇關于SpringBoot+MyBatisPlus中樂觀鎖的實現(xiàn)示例的文章就介紹到這了,更多相關SpringBoot MyBatisPlus樂觀鎖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 史上最通俗理解的Java死鎖代碼演示

    史上最通俗理解的Java死鎖代碼演示

    這篇文章主要給大家介紹了關于Java死鎖代碼演示的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • 運行SpringBoot項目請求響應流程分析以及404和500報錯的解決辦法

    運行SpringBoot項目請求響應流程分析以及404和500報錯的解決辦法

    這篇文章主要介紹了運行Spring Boot項目請求響應流程分析以及404和500報錯的解決辦法,文中通過代碼示例和圖文講解的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下
    2024-12-12
  • springmvc無法訪問/WEB-INF/views下的jsp的解決方法

    springmvc無法訪問/WEB-INF/views下的jsp的解決方法

    本篇文章主要介紹了springmvc無法訪問/WEB-INF/views下的jsp的解決方法,非常具有實用價值,需要的朋友可以參考下
    2017-10-10
  • Java異常處理實例分析

    Java異常處理實例分析

    這篇文章主要介紹了Java異常處理,實例分析了java異常處理的常見用法,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-04-04
  • Spring Cloud實戰(zhàn)技巧之使用隨機端口

    Spring Cloud實戰(zhàn)技巧之使用隨機端口

    這篇文章主要給大家介紹了關于Spring Cloud實戰(zhàn)技巧之使用隨機端口的相關資料,文中介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面跟著小編一起來學習學習吧。
    2017-06-06
  • 詳解maven安裝教程以及解決安裝不成功的解決辦法

    詳解maven安裝教程以及解決安裝不成功的解決辦法

    這篇文章主要介紹了詳解maven安裝教程以及解決安裝不成功的解決辦法,詳細的介紹了幾種解決方法,非常具有實用價值,需要的朋友可以參考下
    2018-12-12
  • SpringBoot教程_創(chuàng)建第一個SpringBoot項目

    SpringBoot教程_創(chuàng)建第一個SpringBoot項目

    這篇文章主要介紹了SpringBoot教程_創(chuàng)建第一個SpringBoot項目,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • MybatisPlus中的多表條件排序查詢

    MybatisPlus中的多表條件排序查詢

    這篇文章主要介紹了MybatisPlus中的多表條件排序查詢,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • 關于java中可變長參數(shù)的定義及使用方法詳解

    關于java中可變長參數(shù)的定義及使用方法詳解

    下面小編就為大家?guī)硪黄P于java中可變長參數(shù)的定義及使用方法詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • Spring中的Sentinel熔斷降級詳解

    Spring中的Sentinel熔斷降級詳解

    這篇文章主要介紹了Spring中的Sentinel熔斷降級詳解,熔斷降級是一種保護系統(tǒng)穩(wěn)定性和可用性的機制,旨在防止故障的擴散和蔓延,提高用戶體驗和信任度,需要的朋友可以參考下
    2023-09-09

最新評論