讲在前头:字段自动填充你可以选择在设计数据库的时候对字段进行函数设计–或者触发器方式,也可以选择我的这种在代码中进行控制。常用于创建时间,更新时间以及乐观锁字段
因为是要填充到数据库中,所以不难想到需要对实体进行一些处理,如下:
@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;
}
上边说的就差不多了,建议实操,下面显示一下操作结果。