当我们在添加或修改数据的时候,数据表里或多或少都会有创建时间、更新时间这样的字段,但是每次在新增或修改的时候手动设置这些字段比较繁琐,那么就可以使用mybatis-plus的自动填充功能。
首先需要在你的实体类上对应的需要操作字段加上注解@TableField
这个注解可以设置fill属性,如下图,比如在修改的时候,需要修改updateTime字段,就设置@TableField(fill=FieldFill.UPDATE)
@Data
public class entity {
private Long id;
@TableField(fill = FieldFill.INSERT)
private Date createTime;
@TableField(fill = FieldFill.INSERT)
private Long createUserId;
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;
@TableField(fill = FieldFill.UPDATE)
private Long updateUserId;
}
设置完字段的属性后,需要自定义一个实现类MyMetaObjectHandler
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
log.info("start insert fill ....");
this.strictInsertFill(metaObject, "createTime", Date.class, new Date());
this.strictInsertFill(metaObject, "updateTime", Date.class, new Date());
// 判断是否有这个字段
if (this.getFieldValByName("createUserId", metaObject) != null) {
// 有的话就更新这个字段
this.strictUpdateFill(metaObject, "createUserId", Date.class, new Date());
}
}
@Override
public void updateFill(MetaObject metaObject) {
log.info("start update fill ....");
this.strictUpdateFill(metaObject, "updateTime", Date.class, new Date());
// 判断是否有这个字段
if (this.getFieldValByName("updateUserId", metaObject) != null) {
// 有的话就更新这个字段
this.strictUpdateFill(metaObject, "updateUserId", Date.class, new Date());
}
}
}
设置完这些之后,在每次使用mybatis-plus执行添加或者修改操作的时候就会自动设置这些字段的值进行新增或修改。