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-05
Java 基礎(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ù)進行增刪改后,Elasticsearch中的數(shù)據(jù),索引也必須跟著做出改變。本文主要來和大家探討一下Elasticsearch和MySQL之間的數(shù)據(jù)同步問題,感興趣的可以了解一下2023-04-04
如何基于SpringMVC實現(xiàn)斷點續(xù)傳(HTTP)
這篇文章主要介紹了如何基于SpringMVC實現(xiàn)斷點續(xù)傳(HTTP),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-01-01
SpringBoot統(tǒng)一響應(yīng)格式及統(tǒng)一異常處理
在我們開發(fā)SpringBoot后端服務(wù)時,一般需要給前端統(tǒng)一響應(yīng)格式,本文主要介紹了SpringBoot統(tǒng)一響應(yīng)格式及統(tǒng)一異常處理2023-05-05
JAVA面試題 從源碼角度分析StringBuffer和StringBuilder的區(qū)別
這篇文章主要介紹了JAVA面試題 從源碼角度分析StringBuffer和StringBuilder的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,下面我們來一起學(xué)習(xí)下吧2019-07-07

