樂觀鎖插件

樂觀鎖與悲觀鎖

樂觀鎖:十分的樂觀,它認(rèn)為不會(huì)出現(xiàn)問題,無論干什么都不去上鎖,

悲觀鎖:十分的悲觀,它認(rèn)為總是會(huì)出現(xiàn)問題,無論干什么都去上鎖,

樂觀鎖插件

意圖:

當(dāng)要更新一條記錄的時(shí)候,希望這條記錄沒有被別人更新

樂觀鎖實(shí)現(xiàn)方式:

  • 取出記錄時(shí),獲取當(dāng)前version
  • 更新時(shí),帶上這個(gè)version
  • 執(zhí)行更新時(shí), set version = newVersion where version = oldVersion
  • 如果version不對,就更新失敗

樂觀鎖原理:

比如我在數(shù)據(jù)庫里要修改一個(gè)id=1,并且version=1的一條數(shù)據(jù),樂觀鎖會(huì)先去查詢id=1的version是否等于1,如果等于就修改,如果不等于就不修改

--樂觀鎖 先查詢,獲得一個(gè)可以判斷的值
--a線程 執(zhí)行更新
update user set name=#{name},version=newVersion where id=1 and version = 1
--b線程 搶先在a線程執(zhí)行完畢之前執(zhí)行  
update user set name=#{name},version=newVersion where id=1 and version = 1
--由于b線程搶先執(zhí)行了,version的值已經(jīng)改變不在是1了,但是又有 and version = 1 的限制,所以a線程就不會(huì)執(zhí)行成功 從而保障了線程的安全

MP中的樂觀鎖插件實(shí)現(xiàn)

數(shù)據(jù)庫新增int類型的 version字段默認(rèn)值為1。

增加pojo實(shí)體類的屬性,并打上@Version注解

@Version //樂觀鎖
private Integer version;

新增MybatisPlusConfig配置類

@Configuration
@EnableTransactionManagement
public class MybatisPlusConfig {
    @Bean
    public OptimisticLockerInterceptor optimisticLockerInterceptor() {
        return new OptimisticLockerInterceptor();
    }
}

測試多線程下的插入操作

 @Test
    void testLocking(){
        //線程A
        User user = userMapper.selectById(1L);
        user.setEmail("4152064@qq.com");
        //線程B搶先修改
        User user2 = userMapper.selectById(1L);
        user2.setEmail("2414506319@qq.com");
        userMapper.updateById(user2);
        //等待B線程執(zhí)行完畢在執(zhí)行A線程
        userMapper.updateById(user);
    }
}

因?yàn)橛辛藰酚^鎖,當(dāng)有多個(gè)線程對同一個(gè)對象進(jìn)行操作時(shí)后操作的線程就無法在繼續(xù)操作,保證了線程的安全

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容