淺談Mybatis樂(lè)觀鎖插件
背景:對(duì)于數(shù)據(jù)庫(kù)的同一條記錄,假如有兩個(gè)人同時(shí)對(duì)數(shù)據(jù)進(jìn)行了修改,然后最終同步到數(shù)據(jù)庫(kù)的時(shí)候,因?yàn)榇嬖谥l(fā),產(chǎn)生的結(jié)果是不可預(yù)料的。最簡(jiǎn)單的解決方式就是通過(guò)給表的記錄加一個(gè)version字段,記錄在修改的時(shí)候需要比較一下version是否匹配,如果匹配就更新,不匹配就直接失敗。更新成功則把version+1,也就是所謂的樂(lè)觀鎖。當(dāng)然這樣的邏輯最好能做到對(duì)開(kāi)發(fā)人員透明,本插件就是來(lái)做這件事情的。
1. 使用方式:在mybatis配置文件中加入如下配置,就完成了。
<plugins> <plugin interceptor="com.chrhc.mybatis.locker.interceptor.OptimisticLocker"/> </plugins>
2. 對(duì)插件配置的說(shuō)明:
上面對(duì)插件的配置默認(rèn)數(shù)據(jù)庫(kù)的樂(lè)觀鎖列對(duì)應(yīng)的Java屬性為version。這里可以自定義屬性命,例如:
<plugins>
<plugin interceptor="com.chrhc.mybatis.locker.interceptor.OptimisticLocker">
<property name="versionColumn" value="xxx"/><!--數(shù)據(jù)庫(kù)的列名-->
<property name="versionField" value="xxx"/> <!--java字段名-->
</plugin>
</plugins>
3. 效果:
之前:update user set name = ?, password = ? where id = ?
之后:update user set name = ?, password = ?, version = version+1 where id = ? and version = ?
4. 對(duì)version的值的說(shuō)明:
1、當(dāng)PreparedStatement獲取到version值之后,插件內(nèi)部會(huì)自動(dòng)自增1。
2、樂(lè)觀鎖的整個(gè)控制過(guò)程對(duì)用戶而言是透明的,這和Hibernate的樂(lè)觀鎖很相似,用戶不需要關(guān)心樂(lè)觀鎖的值。
5.插件原理描述:
插件通過(guò)攔截mybatis執(zhí)行的update語(yǔ)句,在原有sql語(yǔ)句基礎(chǔ)之上增加樂(lè)觀鎖標(biāo)記,比如,原始sql為:
update user set name = ?, password = ? where id = ?,
那么用戶不需要修改sql語(yǔ)句,在插件的幫助之下,會(huì)自動(dòng)將上面的sql語(yǔ)句改寫(xiě)成為:
update user set name = ?, password = ?, version = version + 1 where id = ? and version = ?,
形式,用戶也不用關(guān)心version前后值的問(wèn)題,所有的動(dòng)作對(duì)用戶來(lái)說(shuō)是透明的,由插件自己完成這些功能。
6.默認(rèn)約定:
1、本插件攔截的update語(yǔ)句的Statement都是PreparedStatement,僅針對(duì)這種方式的sql有效;
2、mapper.xml的<update>標(biāo)簽必須要與接口Mapper的方法對(duì)應(yīng)上,也就是使用mybatis推薦的方式,但是多個(gè)接口可以對(duì)應(yīng)一個(gè)mapper.xml的<update>標(biāo)簽;
3、本插件不會(huì)對(duì)sql的結(jié)果做任何操作,sql本身應(yīng)該返回什么就是什么;
4、插件默認(rèn)攔截所有update語(yǔ)句,如果用戶對(duì)某個(gè)update不希望有樂(lè)觀鎖控制,那么在對(duì)應(yīng)的mapper接口方法上面增加@VersionLocker(false)或者@VersionLocker(value = false),這樣插件就不會(huì)對(duì)這個(gè)update做任何操作,等同于沒(méi)有本插件;
5、本插件目前暫時(shí)不支持批量更新的樂(lè)觀鎖,原因是由于批量更新在實(shí)際開(kāi)發(fā)中應(yīng)用場(chǎng)景不多,另外批量更新樂(lè)觀鎖開(kāi)發(fā)難度比較大;
6、Mapper接口的參數(shù)類(lèi)型必須和傳入的實(shí)際類(lèi)型保持一致,這是由于在JDK版本在JDK8以下沒(méi)有任何方法能獲取接口的參數(shù)列表名稱,因此,插件內(nèi)部是使用參數(shù)類(lèi)型和參數(shù)作為映射來(lái)匹配方法簽名的;
github地址:https://github.com/xjs1919/locker
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- SpringBoot整合MyBatis實(shí)現(xiàn)樂(lè)觀鎖和悲觀鎖的示例
- Mybatis-Plus樂(lè)觀鎖配置流程
- SpringBoot+MyBatisPlus中樂(lè)觀鎖的實(shí)現(xiàn)示例
- MyBatisPlus+SpringBoot實(shí)現(xiàn)樂(lè)觀鎖功能詳細(xì)流程
- MyBatis-Plus樂(lè)觀鎖插件的用法小結(jié)
- mybatis?plus樂(lè)觀鎖及實(shí)現(xiàn)詳解
- Mybatis Generator Plugin悲觀鎖實(shí)現(xiàn)示例
- MyBatis實(shí)現(xiàn)樂(lè)觀鎖和悲觀鎖的示例代碼
相關(guān)文章
詳談ThreadLocal-單例模式下高并發(fā)線程安全
這篇文章主要介紹了ThreadLocal-單例模式下高并發(fā)線程安全,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09
springboot+mybatis攔截器方法實(shí)現(xiàn)水平分表操作
這篇文章主要介紹了springboot+mybatis攔截器方法實(shí)現(xiàn)水平分表操作,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-08-08
Java基于享元模式實(shí)現(xiàn)五子棋游戲功能實(shí)例詳解
這篇文章主要介紹了Java基于享元模式實(shí)現(xiàn)五子棋游戲功能,較為詳細(xì)的分析了享元模式的概念、功能并結(jié)合實(shí)例形式詳細(xì)分析了Java使用享元模式實(shí)現(xiàn)五子棋游戲的具體操作步驟與相關(guān)注意事項(xiàng),需要的朋友可以參考下2018-05-05
如何自定義Mybatis-Plus分布式ID生成器(解決ID長(zhǎng)度超過(guò)JavaScript整數(shù)安全范圍問(wèn)題)
MyBatis-Plus默認(rèn)生成的是 64bit 長(zhǎng)整型,而 JS 的 Number 類(lèi)型精度最高只有 53bit,這篇文章主要介紹了如何自定義Mybatis-Plus分布式ID生成器(解決ID長(zhǎng)度超過(guò)JavaScript整數(shù)安全范圍問(wèn)題),需要的朋友可以參考下2024-08-08
SpringMVC使用MultipartFile實(shí)現(xiàn)文件上傳
這篇文章主要為大家詳細(xì)介紹了SpringMVC使用MultipartFile實(shí)現(xiàn)文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04
Java調(diào)用Redis集群代碼及問(wèn)題解決
這篇文章主要介紹了Java調(diào)用Redis集群代碼及問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
Java實(shí)現(xiàn)雪花算法的工具類(lèi)介紹
雪花 (SnowFlake )算法是一種分布式唯一ID生成算法,可以生成全局唯一的ID標(biāo)識(shí)符,就像自然界中雪花一般沒(méi)有相同的雪花,本文和大家分享了一個(gè)雪花算法工具類(lèi),需要的可以收藏一下2023-05-05
詳解Java Proxy動(dòng)態(tài)代理機(jī)制
今天給大家?guī)?lái)的是關(guān)于Java的相關(guān)知識(shí),文章圍繞著Java動(dòng)態(tài)代理機(jī)制展開(kāi),文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06

