Mybatis plus的自動(dòng)填充與樂觀鎖的實(shí)例詳解(springboot)
自動(dòng)填充
項(xiàng)目中經(jīng)常會(huì)遇到一些數(shù)據(jù),每次都使用相同的方式填充,如插入時(shí)間、更新時(shí)間。Mybatis-plus的自動(dòng)填充功能可以幫助我們快速實(shí)現(xiàn)。
1.表中加入create_time,update_time字段
2.實(shí)體類注解填充字段
@TableField(fill= FieldFill.INSERT) private Date createTime; @TableField(fill = FieldFill.INSERT_UPDATE) private Date updateTime;
/*** 默認(rèn)不處理/DEFAULT,/** 插入填充字段/INSERT,/** 更新填充字段/UPDATE,/** 插入和更新填充字段*/INSERT_UPDATE
3.自定義實(shí)現(xiàn)類MyMetaObjectHandler
@Componentpublic class MyMetaObjectHandler implements MetaObjectHandler { /** * * 使用Mybatis-plus執(zhí)行insert操作這個(gè)方法執(zhí)行 */ @Override public void insertFill(MetaObject metaObject) { this.setFieldValByName('createTime',new Date(),metaObject); this.setFieldValByName('updateTime',new Date(),metaObject); } /** * * 使用Mybatis-plus執(zhí)行update操作這個(gè)方法執(zhí)行 */ @Override public void updateFill(MetaObject metaObject) { this.setFieldValByName('updateTime',new Date(),metaObject); }}
setFieldValByName中有三個(gè)參數(shù),第一個(gè)是字段名,第二個(gè)是要填充的數(shù)據(jù),第三個(gè)參數(shù)寫成metaObject就可以。
測(cè)試插入:
測(cè)試修改:
發(fā)現(xiàn)插入數(shù)據(jù)的時(shí)候會(huì)自動(dòng)將這兩個(gè)數(shù)據(jù)填充當(dāng)前時(shí)間,更新的時(shí)候會(huì)只講更新時(shí)間更改為當(dāng)前時(shí)間。
樂觀鎖
當(dāng)項(xiàng)目中出現(xiàn)并發(fā)操作時(shí),會(huì)出現(xiàn)丟失更新問題,即A與B都查詢到money字段為100,A修改money+900,改為1000。這時(shí)B也提交修改,money+50,改為150。A的修改就丟失了。解決這種情況有兩種方法:悲觀鎖和樂觀鎖,悲觀鎖就是只能一個(gè)一個(gè)操作,A操作的時(shí)候B只能等著,等A提交完成了B才能查詢。Mybatis-plus自帶樂觀鎖:創(chuàng)建一個(gè)version字段,當(dāng)A與B可以同時(shí)操作,當(dāng)A提交的時(shí)候會(huì)看當(dāng)前版本號(hào)與查詢時(shí)候的版本號(hào)是否一致,一致才能提交成功,否則提交失敗,提交成功會(huì)把當(dāng)前版本號(hào)+1。
1.數(shù)據(jù)庫中加入version字段,并在實(shí)體類中加入version屬性。
加上 @Version注解
@Version private Integer version;
2.編寫配置類引入樂觀鎖插件
@Configuration@MapperScan('com.zyw.mpdemo.mapper')public class MpConfig { @Bean public OptimisticLockerInterceptor optimisticLockerInterceptor() { return new OptimisticLockerInterceptor(); }}
3.編寫測(cè)試
用兩個(gè)對(duì)象查詢同一個(gè)id,做不同的修改,然后依次提交。
@Override public void test(Account account) { Account account1 = accountMapper.selectById(1326188266440888321L); Account account2 = accountMapper.selectById(1326188266440888321L); account1.setMoney(account.getMoney()); account2.setMoney(account.getMoney()+100); accountMapper.updateById(account1); accountMapper.updateById(account2); }
第一次成功,第二次提交失敗,因?yàn)榈诙翁峤坏臅r(shí)候的版本號(hào)與查詢到的不一致。
到此這篇關(guān)于Mybatis plus的自動(dòng)填充與樂觀鎖(springboot)的文章就介紹到這了,更多相關(guān)Mybatis plus自動(dòng)填充樂觀鎖內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. Java之JSP教程九大內(nèi)置對(duì)象詳解(中篇)2. 基于python計(jì)算滾動(dòng)方差(標(biāo)準(zhǔn)差)talib和pd.rolling函數(shù)差異詳解3. CSS自定義滾動(dòng)條樣式案例詳解4. 使用css實(shí)現(xiàn)全兼容tooltip提示框5. JS繪圖Flot如何實(shí)現(xiàn)動(dòng)態(tài)可刷新曲線圖6. 詳解CSS不定寬溢出文本適配滾動(dòng)7. 基于android studio的layout的xml文件的創(chuàng)建方式8. 詳解Python中openpyxl模塊基本用法9. Java發(fā)送http請(qǐng)求的示例(get與post方法請(qǐng)求)10. springboot基于Redis發(fā)布訂閱集群下WebSocket的解決方案
