springboot自动填充配置
很多数据库的表大多都会设置两个固定的字段:create_time 和 update_time
而每次进行业务操作比如更新或插入数据的时候,都要给这两个字段插入数据。
可以配置配置类,当数据被插入的时候,自动插入更新时间和插入时间
配置类
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;
/**
* 默认值填充拦截器
* @author fzg
*/
@Slf4j
@Component
public class FieldMetaObjectHandler implements MetaObjectHandler {
/**新增时间**/
private final String TIME_CREATE = "createTime";
/**更新时间**/
private final String TIME_UPDATE = "updateTime";
/**
* 新增默认填充器
* @param metaObject
*/
@Override
public void insertFill(MetaObject metaObject) {
//添加时间、最后更新时间
this.strictInsertFill(metaObject, TIME_CREATE, LocalDateTime.class, LocalDateTime.now());
this.strictInsertFill(metaObject, TIME_UPDATE, LocalDateTime.class, LocalDateTime.now());
}
/**
* 更新默认填充器
* @param metaObject
*/
@Override
public void updateFill(MetaObject metaObject) {
//最后更新时间
this.strictInsertFill(metaObject, TIME_UPDATE, LocalDateTime.class, LocalDateTime.now());
}
}
在实体类中加注解
import com.baomidou.mybatisplus.annotation.TableField;
import java.io.Serializable;
import java.time.LocalDateTime;
import lombok.Data;
import lombok.EqualsAndHashCode;
/**
* <p>
*
* </p>
*
* @author fzg
* @since 2022-06-20
*/
@Data
@EqualsAndHashCode(callSuper = false)
public class 实体类名 implements Serializable {
/**
* 创建时间
*/
@TableField(fill = FieldFill.INSERT)
private LocalDateTime createTime;
/**
* 更新时间
*/
@TableField(fill = FieldFill.INSERT_UPDATE)
private LocalDateTime updateTime;
}
这样在数据插入或更新的时候,就不用管这两个字段了