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