MyBatis-Plus自動(dòng)化填充的踩坑記錄及解決
最近在做重構(gòu)老項(xiàng)目時(shí),覺得MyBatis-Plus的自動(dòng)填充功能非常適合用來替代之前業(yè)務(wù)中手動(dòng)維護(hù)創(chuàng)建時(shí)間,更新時(shí)間,創(chuàng)建用戶,更新用戶等字段。
但在開發(fā)的過程中也遇到了一個(gè)小問題,與大家分享下這個(gè)容易踩坑的地方。
問題再現(xiàn)
在開發(fā)的過程中,使用了MyBatis-Plus開發(fā)插件,根據(jù)表信息自動(dòng)生成了表的實(shí)體類,然后又根據(jù)MyBatis-Plus的官方文檔,添加了注解及自定義實(shí)現(xiàn)類,然后發(fā)現(xiàn)運(yùn)行起來時(shí)間數(shù)據(jù)沒有插入。
情況如下圖所示:
問題分析與源碼原理分析
分析打印的SQL日志,發(fā)現(xiàn)更新時(shí)已經(jīng)添加update_time字段,故排除實(shí)體類的注解問題。
轉(zhuǎn)而分析MyMetaObjectHandler自定義實(shí)現(xiàn)類,經(jīng)過對(duì)比發(fā)現(xiàn),它其中使用的LocalDateTime類型,而使用插件生成則會(huì)把Mysql數(shù)據(jù)庫里DateTime類型自動(dòng)生成為Date類型。
猜測問題就是時(shí)間類型不一樣導(dǎo)致。然后打斷點(diǎn)進(jìn)入MyMetaObjectHandler方法,對(duì)MyBatis-Plus源碼進(jìn)行分析:
(1)實(shí)際填充方法如下
default MetaObjectHandler strictFill(boolean insertFill, TableInfo tableInfo, MetaObject metaObject, List<StrictFill<?, ?>> strictFills) { if (insertFill && tableInfo.isWithInsertFill() || !insertFill && tableInfo.isWithUpdateFill()) { strictFills.forEach((i) -> { String fieldName = i.getFieldName(); Class<?> fieldType = i.getFieldType(); tableInfo.getFieldList().stream().filter((j) -> { return j.getProperty().equals(fieldName) && fieldType.equals(j.getPropertyType()) && (insertFill && j.isWithInsertFill() || !insertFill && j.isWithUpdateFill()); }).findFirst().ifPresent((j) -> { this.strictFillStrategy(metaObject, fieldName, i.getFieldVal()); }); }); } return this; }
(2)定位匹配規(guī)則代碼
return j.getProperty().equals(fieldName) && fieldType.equals(j.getPropertyType()) && (insertFill && j.isWithInsertFill() || !insertFill && j.isWithUpdateFill());
可以將其拆分成三部分,分別是
//判斷MyMetaObjectHandler中名稱是否和更新數(shù)據(jù)的名稱相同 j.getProperty().equals(fieldName) //判斷自MyMetaObjectHandler中類型是否和更新數(shù)據(jù)的類型相同 fieldType.equals(j.getPropertyType()) //判斷字段insert及update填充的符合情況 (insertFill && j.isWithInsertFill() || !insertFill && j.isWithUpdateFill())
(3)計(jì)算器參數(shù)對(duì)比
在此就能發(fā)現(xiàn)問題,propertyType中的值為class java.util.Date,而fieldType中的值為class java.time.LocalDateTime,類型不匹配導(dǎo)致填充失敗。
問題解決方法
將自動(dòng)生成實(shí)體類的時(shí)間類型改成了LocalDateTime,問題便得到了解決。
總結(jié)
開發(fā)中時(shí)常遇到這種小問題,特別是依賴插件生成的代碼,因?yàn)椴皇亲约壕帉懙模欢ㄒ屑?xì)檢查核對(duì)。
LocalDateTime是Java 8引入的時(shí)間日期類,它是final修飾的不可變類型,不可修改,線程安全,而且提供了更加友好好用的日期操作,平時(shí)學(xué)習(xí)工作建議使用LocalDateTime。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java?mybatis如何操作postgresql?array數(shù)組類型
這篇文章主要介紹了java?mybatis如何操作postgresql?array數(shù)組類型,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01Springboot內(nèi)置Tomcat配置參數(shù)調(diào)優(yōu)方式
這篇文章主要介紹了Springboot內(nèi)置Tomcat配置參數(shù)調(diào)優(yōu)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06使用apache 的FileUtils處理文件的復(fù)制等操作方式
這篇文章主要介紹了使用apache 的FileUtils處理文件的復(fù)制等操作方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07Java Socket+mysql實(shí)現(xiàn)簡易文件上傳器的代碼
最近在做一個(gè)小項(xiàng)目,項(xiàng)目主要需求是實(shí)現(xiàn)一個(gè)文件上傳器,通過客戶端的登陸,把本地文件上傳到服務(wù)器的數(shù)據(jù)庫(本地的)。下面通過本文給大家分享下實(shí)現(xiàn)代碼,感興趣的朋友一起看看吧2016-10-10Java中具有映射關(guān)系的容器:數(shù)組和Map的區(qū)別說明
這篇文章主要介紹了Java中具有映射關(guān)系的容器:數(shù)組和Map的區(qū)別說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-09-09Java使用責(zé)任鏈模式處理學(xué)生請假問題詳解
這篇文章主要介紹了Java使用責(zé)任鏈模式處理學(xué)生請假問題,結(jié)合實(shí)例形式詳細(xì)分析了責(zé)任鏈模式的概念、原理及Java使用責(zé)任鏈模式處理學(xué)生請假問題的相關(guān)步驟、操作技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下2018-04-04