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

MyBatis-Plus自動(dòng)化填充的踩坑記錄及解決

 更新時(shí)間:2023年03月30日 09:36:58   作者:hizoo  
這篇文章主要介紹了MyBatis-Plus自動(dòng)化填充的踩坑記錄及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

最近在做重構(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ù)組類型

    這篇文章主要介紹了java?mybatis如何操作postgresql?array數(shù)組類型,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    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)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 使用apache 的FileUtils處理文件的復(fù)制等操作方式

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

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

    JAVA獲取文件絕對(duì)路徑的方法

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

    Java Socket+mysql實(shí)現(xiàn)簡易文件上傳器的代碼

    最近在做一個(gè)小項(xiàng)目,項(xiàng)目主要需求是實(shí)現(xiàn)一個(gè)文件上傳器,通過客戶端的登陸,把本地文件上傳到服務(wù)器的數(shù)據(jù)庫(本地的)。下面通過本文給大家分享下實(shí)現(xiàn)代碼,感興趣的朋友一起看看吧
    2016-10-10
  • Java中具有映射關(guān)系的容器:數(shù)組和Map的區(qū)別說明

    Java中具有映射關(guān)系的容器:數(shù)組和Map的區(qū)別說明

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

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

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

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

    EhCache是一個(gè)比較成熟的Java緩存框架,Springboot對(duì)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é)合實(shí)例形式詳細(xì)分析了責(zé)任鏈模式的概念、原理及Java使用責(zé)任鏈模式處理學(xué)生請假問題的相關(guān)步驟、操作技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2018-04-04

最新評(píng)論