MySQL_公共字段自动填充

本文介绍了如何在数据库字段中实现自动填充,特别是针对创建时间、更新时间和乐观锁字段。通过@TableField注解定义填充时机,并在MetaObjectHandler中设置填充规则,如填充当前日期。在插入和更新时,利用MetaObjectHandler的insertFill和updateFill方法对时间戳和乐观锁版本号进行处理。此方法确保了数据的完整性和一致性。
摘要由CSDN通过智能技术生成

讲在前头:字段自动填充你可以选择在设计数据库的时候对字段进行函数设计–或者触发器方式,也可以选择我的这种在代码中进行控制。常用于创建时间,更新时间以及乐观锁字段
因为是要填充到数据库中,所以不难想到需要对实体进行一些处理,如下:

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class Account implements Serializable {

    private static final long serialVersionUID=1L;

    @TableId(value = "id", type = IdType.ID_WORKER)
    private Long id;

    private String name;

    private Double money;

    @TableField(fill = FieldFill.INSERT)
    private Date createTime;

    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;

    @TableField(value = "version", fill = FieldFill.INSERT_UPDATE)
    private String version;

}

根据前提和我对实体的处理,不难看出其实做的改变就只是在创建时间,更新时间以及乐观锁上加了@TableField(fill = XXX)注解,那么久进入注解中看一下具体含义

public enum FieldFill {
    DEFAULT,
    INSERT,
    UPDATE,
    INSERT_UPDATE;

    private FieldFill() {
    }
}

根据小学英语的翻译以及对FieldFill枚举的观察,我们可以得出一个结论,这个注解的意思就是说->什么时候填充这个字段,然后我们就可以根据这个枚举提供的属性知道一共有四种填充类型:默认(任何时候),插入时,更新时,插入以及更新时。
到现在你不会就以为在这些字段上边设置上这些注解就能够实现了吧,那我只能说你太天真了,仔细想一下你就能知道,现在只是声明了什么时候去填充这些字段,但是填充字段的规则我们还没有写,所以还需要设置规则。

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        this.setFieldValByName("createTime", new Date(), metaObject);
        this.setFieldValByName("updateTime", new Date(), metaObject);
        this.setFieldValByName("version", metaObject.getValue("id") +"***"+ new Date(), metaObject);
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        this.setFieldValByName("updateTime", new Date(), metaObject);
        this.setFieldValByName("version", metaObject.getValue("id") +"***"+ new Date(), metaObject);
    }
}

上边是直接把规则注入到spring容器中,交给spring来帮助我们管理。对创建时间以及更新时间字段填充规则没什么可说的,主要来说一下version,也就是乐观锁的填充规则,首先setFieldValByName方法翻译一下就是根据字段名称填充字段值,首先第一个参数就是字段名称,第二个参数是字段值,第三个字段是要操作的metaObject(可以理解为源对象,也就是正在操作的数据实体源对象)

default MetaObjectHandler setFieldValByName(String fieldName, Object fieldVal, MetaObject metaObject) {
    if (Objects.nonNull(fieldVal) && metaObject.hasSetter(fieldName)) {
        metaObject.setValue(fieldName, fieldVal);
    }

    return this;
}

上边说的就差不多了,建议实操,下面显示一下操作结果。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

new_repo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值