MyBatis-Plus自動化填充的踩坑記錄及解決
最近在做重構(gòu)老項目時,覺得MyBatis-Plus的自動填充功能非常適合用來替代之前業(yè)務(wù)中手動維護創(chuàng)建時間,更新時間,創(chuàng)建用戶,更新用戶等字段。
但在開發(fā)的過程中也遇到了一個小問題,與大家分享下這個容易踩坑的地方。
問題再現(xiàn)
在開發(fā)的過程中,使用了MyBatis-Plus開發(fā)插件,根據(jù)表信息自動生成了表的實體類,然后又根據(jù)MyBatis-Plus的官方文檔,添加了注解及自定義實現(xiàn)類,然后發(fā)現(xiàn)運行起來時間數(shù)據(jù)沒有插入。
情況如下圖所示:



問題分析與源碼原理分析
分析打印的SQL日志,發(fā)現(xiàn)更新時已經(jīng)添加update_time字段,故排除實體類的注解問題。
轉(zhuǎn)而分析MyMetaObjectHandler自定義實現(xiàn)類,經(jīng)過對比發(fā)現(xiàn),它其中使用的LocalDateTime類型,而使用插件生成則會把Mysql數(shù)據(jù)庫里DateTime類型自動生成為Date類型。
猜測問題就是時間類型不一樣導(dǎo)致。然后打斷點進入MyMetaObjectHandler方法,對MyBatis-Plus源碼進行分析:
(1)實際填充方法如下
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)計算器參數(shù)對比

在此就能發(fā)現(xiàn)問題,propertyType中的值為class java.util.Date,而fieldType中的值為class java.time.LocalDateTime,類型不匹配導(dǎo)致填充失敗。
問題解決方法
將自動生成實體類的時間類型改成了LocalDateTime,問題便得到了解決。


總結(jié)
開發(fā)中時常遇到這種小問題,特別是依賴插件生成的代碼,因為不是自己編寫的,一定要仔細檢查核對。
LocalDateTime是Java 8引入的時間日期類,它是final修飾的不可變類型,不可修改,線程安全,而且提供了更加友好好用的日期操作,平時學(xué)習(xí)工作建議使用LocalDateTime。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
java?mybatis如何操作postgresql?array數(shù)組類型
這篇文章主要介紹了java?mybatis如何操作postgresql?array數(shù)組類型,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01
Springboot內(nèi)置Tomcat配置參數(shù)調(diào)優(yōu)方式
這篇文章主要介紹了Springboot內(nèi)置Tomcat配置參數(shù)調(diào)優(yōu)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06
使用apache 的FileUtils處理文件的復(fù)制等操作方式
這篇文章主要介紹了使用apache 的FileUtils處理文件的復(fù)制等操作方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
Java Socket+mysql實現(xiàn)簡易文件上傳器的代碼
最近在做一個小項目,項目主要需求是實現(xiàn)一個文件上傳器,通過客戶端的登陸,把本地文件上傳到服務(wù)器的數(shù)據(jù)庫(本地的)。下面通過本文給大家分享下實現(xiàn)代碼,感興趣的朋友一起看看吧2016-10-10
Java中具有映射關(guān)系的容器:數(shù)組和Map的區(qū)別說明
這篇文章主要介紹了Java中具有映射關(guān)系的容器:數(shù)組和Map的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
Java使用責(zé)任鏈模式處理學(xué)生請假問題詳解
這篇文章主要介紹了Java使用責(zé)任鏈模式處理學(xué)生請假問題,結(jié)合實例形式詳細分析了責(zé)任鏈模式的概念、原理及Java使用責(zé)任鏈模式處理學(xué)生請假問題的相關(guān)步驟、操作技巧與相關(guān)注意事項,需要的朋友可以參考下2018-04-04

