数据库设计>>>创建时间/更新时间自动填充

数据库设计>>>创建时间/更新时间自动填充@TOC

创建时间/更新时间自动填充

阿里巴巴开发手册:所有的数据库表都要配置上gmt_create、gmt_modified!而且需要自动化!

方式一

数据库级别(工作中一般不用, 这种方式不用代码实现,数据库自动填充)

1、在表中新增字段 gmt_create, gmt_modified
2、把实体类同步

private Date gmtCreate;
private Date gmtModified;

3、数据库设计
数据库设计

测试:

更新一条记录

@Test
    void upDataUser() {
   
   
        User user = new User();
        user.setId(1347883372479614979L);
        user.setName("刘德华");
        user.setAge(58);
        user.setEmail("[email protected]");

        int result = userMapper.updateById(user);
        System.out.println("result>>>" + result);
        System.out.println("user" + user);
    }

更新后的结果:
在这里插入图片描述

方式二:代码级别

1、数据库字段
在这里插入图片描述

2、实体类字段属性上需要增加注解

@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
   
   
    @TableId(type = IdType.AUTO)
    private Long id;
    private String name;
    private Integer age;
    private String email;
    @TableField(value = "gmt_create",fill = FieldFill.INSERT)
    private LocalDateTime gmtCreate;

    @TableField( value = "gmt_modified",fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime gmtModified;
}

3、编写处理器来处理这个注解即可!(可以参考官网)
“gmtModified” 指的是实体类属性的名字 还有要注意日期类型一样

package link.zishu.handler;

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;

import java.time.LocalDateTime;
import java.util.Date;

@Component // 一定不要忘记把处理器加到IOC容器中!
public class MyMetaObjectHandler implements MetaObjectHandler {
   
   
    // 插入时的填充策略
    @Override
    public void insertFill(MetaObject metaObject) {
   
   
        System.out.println("start insert fill.....");
        this.strictInsertFill(metaObject, "gmtCreate", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐使用)
        this.strictInsertFill(metaObject, "gmtModified", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐使用)
    }

    // 更新时的填充策略
    @Override
    public void updateFill(MetaObject metaObject) {
   
   
        //"gmtModified" 指的是实体类属性的名字     还有要注意日期类型一样
        this.strictUpdateFill(metaObject, "gmtModified", LocalDateTime.class, LocalDateTime.now());
    }
}

测试

@Test
    void upDataUser() {
   
   
        User user = new User();
        user.setId(1347883372479614988L);
        user.setName("刘德华");
        user.setAge(58);
        user.setEmail("[email protected]");

        int result = userMapper.updateById(user);
        System.out.println("result>>>" + result);
        System.out.println("user" + user);
    }

结果

在这里插入图片描述

附 (注解填充字段的选项)

public enum FieldFill {
   
   
    /**
     * 默认不处理
     */
    DEFAULT,
    /**
     * 插入填充字段
     */
    INSERT,
    /**
     * 更新填充字段
     */
    UPDATE,
    /**
     * 插入和更新填充字段
     */
    INSERT_UPDATE
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章