Mybatis-Plus @TableField自動填充時間為null的問題解決
最近做的一個項目中用到了mybatis-plus的自動填充
主要服務(wù)于數(shù)據(jù)庫表中的創(chuàng)建時間字段以及最后修改時間字段
期望效果是在執(zhí)行添加或更新操作時自動填充相應(yīng)時間
但是發(fā)現(xiàn)執(zhí)行操作后相應(yīng)字段填充值為null
省流:將實體類中的TableField的value項去掉,并將MetaObjectHandler實現(xiàn)類中的相應(yīng)方法的fieldName都改為了駝峰式命名即可。(注意:java實體類中屬性名一般為駝峰式命名)
我使用的mybatis-plus版本為3.5.1
首先是對應(yīng)的實體類中的這兩個字段如下:
/** * 創(chuàng)建時間 */ @TableField(value = "gmt_create", fill = FieldFill.INSERT) @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8") private LocalDateTime gmtCreate; /** * 修改時間 */ @TableField(value = "gmt_modified", fill = FieldFill.INSERT_UPDATE) @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8") private LocalDateTime gmtModified;
然后我實現(xiàn)的MetaObjectHandler接口如下:
package edu.web.utils; import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler; import lombok.extern.slf4j.Slf4j; import org.apache.ibatis.reflection.MetaObject; import org.springframework.stereotype.Component; import java.time.LocalDateTime; @Slf4j // 添加日志 @Component // 注入Spring容器中 public class MyMetaObjectHandler implements MetaObjectHandler { /** * 插入時的填充策略 * * @param metaObject */ @Override public void insertFill(MetaObject metaObject) { // 添加日志 log.info("start insert fill............"); /** * String fieldName: 需要插入的字段 * Object fieldVal: 需要插入的類型 * MetaObject metaObject: 需要給哪個數(shù)據(jù)處理 */ this.strictInsertFill(metaObject, "gmt_create", LocalDateTime.class, LocalDateTime.now()); this.strictUpdateFill(metaObject, "gmt_modified", LocalDateTime.class, LocalDateTime.now()); } /** * 更新時的填充策略 * * @param metaObject */ @Override public void updateFill(MetaObject metaObject) { log.info("end update fill............"); /** * 更新的時候需要更新的字段 */ this.strictUpdateFill(metaObject, "gmt_modified", LocalDateTime.class, LocalDateTime.now()); } }
乍一看貌似沒有任何問題,但實際使用中的結(jié)果....見下圖:
上圖為指定行記錄的更新操作結(jié)果,我們發(fā)現(xiàn)更新值為null
這時候來看看IDEA中輸出的日志吧
因此,我在網(wǎng)上查閱了許多博主的相關(guān)文章以及方法,但是沒有一個能夠解決我的問題
突然我靈光一閃,有沒有可能是因為fieldname的命名有關(guān)呢,于是乎我將實體類中的TableField的value項去掉,并將MetaObjectHandler實現(xiàn)類中的相應(yīng)方法的fieldName都改為了駝峰式命名,然后居然就成功了!
修改后的實體類如下:
/** * 創(chuàng)建時間 */ @TableField(fill = FieldFill.INSERT) @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8") private LocalDateTime gmtCreate; /** * 修改時間 */ @TableField(fill = FieldFill.INSERT_UPDATE) @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8") private LocalDateTime gmtModified;
修改后的MetaObjectHandler實現(xiàn)類如下:
package edu.web.utils; import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler; import lombok.extern.slf4j.Slf4j; import org.apache.ibatis.reflection.MetaObject; import org.springframework.stereotype.Component; import java.time.LocalDateTime; @Slf4j // 添加日志 @Component // 注入Spring容器中 public class MyMetaObjectHandler implements MetaObjectHandler { /** * 插入時的填充策略 * * @param metaObject */ @Override public void insertFill(MetaObject metaObject) { // 添加日志 log.info("start insert fill............"); /** * String fieldName: 需要插入的字段 * Object fieldVal: 需要插入的類型 * MetaObject metaObject: 需要給哪個數(shù)據(jù)處理 */ this.strictInsertFill(metaObject, "gmtCreate", LocalDateTime.class, LocalDateTime.now()); this.strictUpdateFill(metaObject, "gmtModified", LocalDateTime.class, LocalDateTime.now()); } /** * 更新時的填充策略 * * @param metaObject */ @Override public void updateFill(MetaObject metaObject) { log.info("end update fill............"); /** * 更新的時候需要更新的字段 */ this.strictUpdateFill(metaObject, "gmtModified", LocalDateTime.class, LocalDateTime.now()); } }
到此這篇關(guān)于Mybatis-Plus @TableField自動填充時間為null的問題解決的文章就介紹到這了,更多相關(guān)Mybatis-Plus @TableField自動填充時間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
RestTemplate get請求攜帶headers自動拼接參數(shù)方式
這篇文章主要介紹了RestTemplate get請求攜帶headers自動拼接參數(shù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07自定義的Troop<T>泛型類( c++, java和c#)的實現(xiàn)代碼
這篇文章主要介紹了自定義的Troop<T>泛型類( c++, java和c#)的實現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2017-05-05Java 基礎(chǔ) byte[]與各種數(shù)據(jù)類型互相轉(zhuǎn)換的簡單示例
這篇文章主要介紹了Java 基礎(chǔ) byte[]與各種數(shù)據(jù)類型互相轉(zhuǎn)換的簡單示例的相關(guān)資料,這里對byte[]類型對long,int,double,float,short,cahr,object,string類型相互轉(zhuǎn)換的實例,需要的朋友可以參考下2017-01-01一文詳解Elasticsearch和MySQL之間的數(shù)據(jù)同步問題
Elasticsearch中的數(shù)據(jù)是來自于Mysql數(shù)據(jù)庫的,因此當(dāng)數(shù)據(jù)庫中的數(shù)據(jù)進(jìn)行增刪改后,Elasticsearch中的數(shù)據(jù),索引也必須跟著做出改變。本文主要來和大家探討一下Elasticsearch和MySQL之間的數(shù)據(jù)同步問題,感興趣的可以了解一下2023-04-04如何基于SpringMVC實現(xiàn)斷點續(xù)傳(HTTP)
這篇文章主要介紹了如何基于SpringMVC實現(xiàn)斷點續(xù)傳(HTTP),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-01-01SpringBoot統(tǒng)一響應(yīng)格式及統(tǒng)一異常處理
在我們開發(fā)SpringBoot后端服務(wù)時,一般需要給前端統(tǒng)一響應(yīng)格式,本文主要介紹了SpringBoot統(tǒng)一響應(yīng)格式及統(tǒng)一異常處理2023-05-05JAVA面試題 從源碼角度分析StringBuffer和StringBuilder的區(qū)別
這篇文章主要介紹了JAVA面試題 從源碼角度分析StringBuffer和StringBuilder的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,下面我們來一起學(xué)習(xí)下吧2019-07-07