首页 > 其他分享 >springboot自动填充配置(创建更新时间)

springboot自动填充配置(创建更新时间)

时间:2022-11-18 11:01:17浏览次数:52  
标签:metaObject springboot 填充 创建 TIME 更新 LocalDateTime import class

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;
    
}

这样在数据插入或更新的时候,就不用管这两个字段了

标签:metaObject,springboot,填充,创建,TIME,更新,LocalDateTime,import,class
From: https://www.cnblogs.com/Fantasyfzg/p/16902514.html

相关文章