MybatisPlus插件自動維護(hù)更新和創(chuàng)建時間方式
為什么要自動去維護(hù)這兩個時間
在實際開發(fā)中基本上每張表中都有這兩個類型的字段,創(chuàng)建時間和修改時間。是為了保證數(shù)據(jù)的可追溯性,當(dāng)然肯定還是有操作日志記錄表用來做追溯記錄。
開發(fā)中每一次的創(chuàng)建更新都需要手動去設(shè)置這一次操作的時間,會有很多的代碼冗余。
創(chuàng)建時間還好,只是在創(chuàng)建的時候去維護(hù)但是更新時間并不能通過DB去維護(hù),MybatisPlus為我們提供了MetaObjectHandler 接口
面我們使用整個接口進(jìn)行操作
先準(zhǔn)備一下兩個實體類
這個我們繼承了一下 公共字段 PublicField
@Data
@TableName("sys_log")
public class SysLog extends PublicField implements Serializable {
private static final long serialVersionUID = 1L;
/**
* 操作IP
*/
private String ip;
/**
* 操作類型 1 操作記錄2異常記錄
*/
private Integer runType;
/**
* 日志類型 1是登錄日志2是操作日志
*/
private Integer logType;
/**
* 操作位置 1是租戶 2是boss
*/
private Integer whereType;
/**
* 操作人
*/
private String userName;
/**
* 操作描述
*/
private String description;
/**
* 請求方法
*/
private String actionMethod;
private String actionUrl;
/**
* 請求參數(shù)
*/
private String params;
/**
* 瀏覽器
*/
private String browser;
/**
* 類路徑
*/
private String classPath;
/**
* 請求方法
*/
private String requestMethod;
/**
* 開始時間
*/
private String startTime;
/**
* 完成時間
*/
private String finishTime;
/**
* 消耗時間
*/
private Long consumingTime;
/**
* 異常詳情信息
*/
private String exDesc;
/**
* 異常描述
*/
private String exDetail;
/**
* 租戶標(biāo)識
*/
private String tenantDatakey;
/**
* 操作地點
*/
private String location;
/**
* 操作系統(tǒng)
*/
private String os;
/**
* 請求狀態(tài)
*
*/
public Integer status;
/**
* 返回數(shù)據(jù)
*/
private String returnData;
}公共字段類:
@Data
public class PublicField {
@TableId(value = "id" ,type = IdType.AUTO)
@ApiModelProperty(value = "ID")
private Integer id;
/**
* 創(chuàng)建時間
*/
@ApiModelProperty(value = "創(chuàng)建時間")
@TableField(value = "create_date",fill = FieldFill.INSERT)
private Date createDate;
/**
* 修改日期
*/
@ApiModelProperty(value = "修改時間")
@TableField(value ="update_date" ,fill= FieldFill.INSERT_UPDATE)
private Date updateDate;
}下面我們配置一下
@Component
@Slf4j
public class MybatisPlusBaseHandler implements MetaObjectHandler {
//重寫一下insertFill方法 在插入時進(jìn)行時間的自動維護(hù)
@Override
public void insertFill(MetaObject metaObject) {
log.info("新增更新時間-------------------------");
this.strictInsertFill(metaObject,"createDate", Date.class,new Date());
this.strictUpdateFill(metaObject,"updateDate",Date.class,new Date());
}
// 修改操作是進(jìn)行時間的維護(hù)
@Override
public void updateFill(MetaObject metaObject) {
log.info("修改更新時間-------------------------");
this.strictUpdateFill(metaObject,"updateDate",Date.class,new Date());
}
}測試插入一條記錄

輸出結(jié)果:

@Test
public void inserint(){
SysLog sysLog = new SysLog();
sysLog.setId(2555);
sysLog.setDescription("測試修改時間能不能自動更新");
iLogServicel.updateById(sysLog);
}輸出結(jié)果:

在DB中也可以看到修改時間已經(jīng)更新(因為創(chuàng)建的時候修改時間和創(chuàng)建時間是樣的現(xiàn)在 修改時間已經(jīng)更新)

最后我貼一下我的maven
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.3.2</version>
</dependency>總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
通過Java創(chuàng)建Socket連接到服務(wù)器方式
這篇文章主要介紹了通過Java創(chuàng)建Socket連接到服務(wù)器方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11
metershpere實現(xiàn)調(diào)用自定義jar包中的方法
在MeterSphere接口測試中,面對多層循環(huán)邏輯和邏輯判斷等復(fù)雜情況,直接編寫測試用例往往顯得混亂不便,本文介紹了一個簡化這一過程的方法:首先使用IDEA創(chuàng)建Maven工程,編寫所需邏輯并生成jar包;然后在MeterSphere中上傳此jar包2024-10-10
Feign 集成 Hystrix實現(xiàn)不同的調(diào)用接口不同的設(shè)置方式
這篇文章主要介紹了Feign 集成 Hystrix實現(xiàn)不同的調(diào)用接口不同的設(shè)置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06
SpringBoot后端進(jìn)行數(shù)據(jù)校驗JSR303的使用詳解
這篇文章主要介紹了SpringBoot后端進(jìn)行數(shù)據(jù)校驗JSR303的使用詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
Java線程安全的計數(shù)器簡單實現(xiàn)代碼示例
這篇文章主要介紹了Java線程安全的計數(shù)器簡單實現(xiàn)代碼示例,具有一定參考價值,需要的朋友可以了解下。2017-10-10

