欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis-Plus自動化填充的踩坑記錄及解決

 更新時間:2023年03月30日 09:36:58   作者:hizoo  
這篇文章主要介紹了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ù)組類型

    這篇文章主要介紹了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)方式

    這篇文章主要介紹了Springboot內(nèi)置Tomcat配置參數(shù)調(diào)優(yōu)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 使用apache 的FileUtils處理文件的復(fù)制等操作方式

    使用apache 的FileUtils處理文件的復(fù)制等操作方式

    這篇文章主要介紹了使用apache 的FileUtils處理文件的復(fù)制等操作方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • JAVA獲取文件絕對路徑的方法

    JAVA獲取文件絕對路徑的方法

    這篇文章主要介紹了JAVA獲取文件絕對路徑的方法,涉及針對文件路徑的操作技巧,需要的朋友可以參考下
    2015-02-02
  • Java Socket+mysql實現(xiàn)簡易文件上傳器的代碼

    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ū)別說明

    這篇文章主要介紹了Java中具有映射關(guān)系的容器:數(shù)組和Map的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • MyBatis查詢數(shù)據(jù)返回null的解決

    MyBatis查詢數(shù)據(jù)返回null的解決

    本文主要介紹了MyBatis查詢數(shù)據(jù)返回null的解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • springboot ehcache 配置使用方法代碼詳解

    springboot ehcache 配置使用方法代碼詳解

    EhCache是一個比較成熟的Java緩存框架,Springboot對ehcache的使用非常支持,所以在Springboot中只需做些配置就可使用,且使用方式也簡易,今天給大家分享springboot ehcache 配置使用教程,一起看看吧
    2021-06-06
  • Jemalloc優(yōu)化MySQL和Nginx

    Jemalloc優(yōu)化MySQL和Nginx

    這篇文章主要介紹了Jemalloc優(yōu)化MySQL和Nginx的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • Java使用責(zé)任鏈模式處理學(xué)生請假問題詳解

    Java使用責(zé)任鏈模式處理學(xué)生請假問題詳解

    這篇文章主要介紹了Java使用責(zé)任鏈模式處理學(xué)生請假問題,結(jié)合實例形式詳細分析了責(zé)任鏈模式的概念、原理及Java使用責(zé)任鏈模式處理學(xué)生請假問題的相關(guān)步驟、操作技巧與相關(guān)注意事項,需要的朋友可以參考下
    2018-04-04

最新評論