mybaits-plus自动填充

当我们在添加或修改数据的时候,数据表里或多或少都会有创建时间、更新时间这样的字段,但是每次在新增或修改的时候手动设置这些字段比较繁琐,那么就可以使用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执行添加或者修改操作的时候就会自动设置这些字段的值进行新增或修改。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值