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

数据库设计>>>创建时间/更新时间自动填充@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("1820818361@qq.com");

        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("1820818361@qq.com");

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

在这里插入图片描述

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

public enum FieldFill {
    /**
     * 默认不处理
     */
    DEFAULT,
    /**
     * 插入填充字段
     */
    INSERT,
    /**
     * 更新填充字段
     */
    UPDATE,
    /**
     * 插入和更新填充字段
     */
    INSERT_UPDATE
}
  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值