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

MyBatis-Plus通過version機制實現(xiàn)樂觀鎖的思路

 更新時間:2021年09月25日 09:19:15   作者:西瓜游俠  
version機制的核心思想就是,假設(shè)發(fā)生并發(fā)沖突的幾率很低,只有當更新數(shù)據(jù)的時候采取檢查是否有沖突,而判斷是否有沖突的依據(jù)就是version的值是否被改變了,這篇文章主要介紹了MyBatis-Plus通過version機制實現(xiàn)樂觀鎖的思路,需要的朋友可以參考下

MyBatis-Plus是通過version機制實現(xiàn)樂觀鎖的。

大致思路:

  • 取出記錄,攜帶記錄的當前version;
  • 更新記錄的時候,比較記錄當前的version是否有改變;
  • 如果version未改變,則更新記錄,并更新version,一般值+1
  • 如果version改變了,則不更新記錄。

version機制的核心思想就是,假設(shè)發(fā)生并發(fā)沖突的幾率很低,只有當更新數(shù)據(jù)的時候采取檢查是否有沖突,而判斷是否有沖突的依據(jù)就是version的值是否被改變了。

配置

MyBatis-Plus中配置樂觀鎖分兩步:

  • 實例化OptimisticLockerInnerInterceptor,并添加到MyBatis-Plus的攔截器鏈中;
  • 定義version字段,并在Entity中使用@Version注解注釋version字段。

說明:

支持的數(shù)據(jù)類型只有: intInteger、long、Long、DateTimestamp、LocalDateTime;

整數(shù)類型下 newVersion = oldVersion + 1

newVersion 會回寫到 entity 中;

僅支持 updateById(id)update(entity, wrapper) 方法;

update(entity, wrapper) 方法下, wrapper 不能復用!!!

配置如下:

首先,實例化OptimisticLockerInnerInterceptor,并添加到攔截器鏈中:

@Configuration
public class MyBatisPlusConfig {

    /**
     * 插件配置
     *
     * @return
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        // 向MyBatis-Plus的過濾器鏈中添加分頁攔截器,需要設(shè)置數(shù)據(jù)庫類型(主要用于分頁方言)
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        // 添加樂觀鎖攔截器
        interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
        return interceptor;
    }
}

然后,使用@Version注解:

@Data
@TableName("tb_user")
public class UserEntity {
    private Long id;
    private String name;
    private Integer age;
    private String email;

    @TableField(value = "create_time", fill = FieldFill.INSERT)
    private Date createTime;

    @TableField(value = "update_time", fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;

    @TableLogic(value = "0", delval = "-1")
    @TableField(value = "delete_flag", fill = FieldFill.INSERT)
    private Integer deleteFlag;

    @Version
    @TableField(value = "version", fill = FieldFill.INSERT)
    private Integer version;
}

配置insert時候,version默認值賦1

/**
 * 自動填充字段值得配置
 */
@Component
public class AutoFillFieldValueConfig implements MetaObjectHandler {

    @Override
    public void insertFill(MetaObject metaObject) {
        this.strictInsertFill(metaObject, "createTime", Date.class, new Date());
        this.strictInsertFill(metaObject, "updateTime", Date.class, new Date());
        this.strictInsertFill(metaObject, "deleteFlag", Integer.class, 0);
        this.strictInsertFill(metaObject, "version", Integer.class, 1);
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        this.strictUpdateFill(metaObject, "updateTime", Date.class, new Date());
    }
}

測試一下

1.測試新增記錄

首先新增一條數(shù)據(jù):

@Test
    public void testVersionInsert() {
        // 插入一個新的用戶
        UserEntity newUser = new UserEntity();
        newUser.setId(12L);
        newUser.setName("Kelly");
        newUser.setAge(28);
        newUser.setEmail("Kelly@163.com");
        userMapper.insert(newUser);
    }

控制臺日志:

==>  Preparing: INSERT INTO tb_user ( id, name, age, email, create_time, update_time, delete_flag, version ) VALUES ( ?, ?, ?, ?, ?, ?, ?, ? )
==> Parameters: 12(Long), Kelly(String), 28(Integer), Kelly@163.com(String), 2021-09-25 00:14:23.894(Timestamp), 2021-09-25 00:14:23.896(Timestamp), 0(Integer), 1(Integer)
<==    Updates: 1

數(shù)據(jù)庫數(shù)據(jù):

在這里插入圖片描述

可以看到,新增記錄時,version默認賦值為1

2.測試更新記錄

下面,來測試一下更新記錄,看看version的變化。

   @Test
    public void testVersionUpdate() {
        // 查詢用戶記錄
        UserEntity updateUser = userMapper.selectById(12L);
        // 更新用戶記錄
        updateUser.setId(12L);
        updateUser.setAge(30);
        userMapper.updateById(updateUser);
    }

注意:這里有一個坑!

一定要先查詢出這條數(shù)據(jù),再更新,樂觀鎖才會生效!??!

控制臺打印的日志:

==>  Preparing: SELECT id,name,age,email,create_time,update_time,delete_flag,version FROM tb_user WHERE id=? AND delete_flag=0
==> Parameters: 12(Long)
<==    Columns: id, name, age, email, create_time, update_time, delete_flag, version
<==        Row: 12, Kelly, 30, Kelly@163.com, 2021-09-25 00:14:24, 2021-09-25 00:20:24, 0, 1
<==      Total: 1

......

==>  Preparing: UPDATE tb_user SET name=?, age=?, email=?, create_time=?, update_time=?, version=? WHERE id=? AND version=? AND delete_flag=0
==> Parameters: Kelly(String), 30(Integer), Kelly@163.com(String), 2021-09-25 00:14:24.0(Timestamp), 2021-09-25 00:20:24.0(Timestamp), 2(Integer), 12(Long), 1(Integer)
<==    Updates: 1

數(shù)據(jù)庫數(shù)據(jù):

在這里插入圖片描述

可以看到,version字段由原來的1,更新為2。

到此這篇關(guān)于MyBatis-Plus通過version機制實現(xiàn)樂觀鎖的思路的文章就介紹到這了,更多相關(guān)MyBatis Plus實現(xiàn)樂觀鎖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring框架學習之Spring?@Autowired實現(xiàn)自動裝配的代碼

    Spring框架學習之Spring?@Autowired實現(xiàn)自動裝配的代碼

    自動裝配就是說,你不用手動實現(xiàn)bean之間的組合關(guān)系,只要使用了@Autowired注解,程序就會自動的注入這個需要的bean,前提是你的Spring容器有這個bean,這篇文章主要介紹了Spring?@Autowired實現(xiàn)自動裝配,需要的朋友可以參考下
    2021-12-12
  • SpringBoot整合Swagger3的流程詳解

    SpringBoot整合Swagger3的流程詳解

    這篇文章主要介紹了SpringBoot整合Swagger3的流程詳解,Swagger最核心的類就是Docket、它可以配置作者信息、掃描類型,在SwaggerConfig配置類,添加@Configuration和@EnableOpenApi注解,需要的朋友可以參考下
    2024-01-01
  • Java 反射機制詳解及實例代碼

    Java 反射機制詳解及實例代碼

    本文主要介紹Java 反射機制的知識,這里提供示例代碼幫助大家學習理解此部分知識,有需要的小伙伴可以參考下
    2016-09-09
  • Java實現(xiàn)鏈表的常見操作算法詳解

    Java實現(xiàn)鏈表的常見操作算法詳解

    這篇文章主要介紹了Java實現(xiàn)鏈表的常見操作算法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-09-09
  • Java基礎(chǔ)之詳細總結(jié)五種常用運算符

    Java基礎(chǔ)之詳細總結(jié)五種常用運算符

    在通常代碼邏輯處理中,我們常常都會使用到運算符,今天我們就詳細了解一下運算符的使用以及分類.運算符是對常量或者變量進行操作的符號,它分為算術(shù)運算符,賦值運算符,比較運算符,邏輯運算符以及位運算符.需要的朋友可以參考下
    2021-05-05
  • Java中null相關(guān)注解的實現(xiàn)

    Java中null相關(guān)注解的實現(xiàn)

    本文主要介紹了Java中null相關(guān)注解的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • Java常用的八種排序算法及代碼實現(xiàn)+圖解

    Java常用的八種排序算法及代碼實現(xiàn)+圖解

    這篇文章主要介紹了Java常用的八種排序算法及代碼實現(xiàn),在Java的時候,對于排序的應(yīng)用需要熟練的掌握,這樣才能夠確保Java學習時候能夠有扎實的基礎(chǔ)能力。那Java有哪些排序算法呢?本文小編就來詳細說說Java經(jīng)典的8種排序算法,需要的朋友可以參考一下
    2021-12-12
  • Java模擬登錄正方教務(wù)抓取成績、課表、空教室

    Java模擬登錄正方教務(wù)抓取成績、課表、空教室

    這篇文章主要介紹了Java模擬登錄正方教務(wù)抓取成績、課表、空教室等信息,Java實現(xiàn)模擬登錄正方教務(wù)抓取成績、課表、空教室,通過HttpClient來模擬瀏覽器請求,Jsoup解析網(wǎng)頁內(nèi)容,感興趣的小伙伴們可以參考一下
    2016-04-04
  • WordPress中卸載插件以及移除文章類型組件的代碼示例

    WordPress中卸載插件以及移除文章類型組件的代碼示例

    這篇文章主要介紹了WordPress中卸載插件以及移除文章類型組件的代碼示例,包括卸載函數(shù)鉤子的方法介紹,需要的朋友可以參考下
    2015-12-12
  • Java中用Socket實現(xiàn)HTTP文件上傳實例

    Java中用Socket實現(xiàn)HTTP文件上傳實例

    本篇文章主要介紹了Java中用Socket實現(xiàn)HTTP文件上傳實例,詳細的介紹了通過讀取Socket的輸入流來實現(xiàn)一個文件上傳的功能,有興趣的同學可以一起了解一下
    2017-04-04

最新評論