MetaObjectHandler -------------实现数据库字段的自动填充

  MetaObjectHandler 是 MyBatis-Plus 框架提供的一个接口,用于在执行数据库操作时自动填充实体类的字段值。它提供了一些默认方法,可以在插入和更新操作时自动填充指定字段的值,以简化开发过程并提高代码的可维护性。

        先来看看这个MetaObjectHandler 接口,其中

  • void insertFill(MetaObject metaObject);
  • void updateFill(MetaObject metaObject);

定义实体类:

public class User {
    @TableField(fill = FieldFill.INSERT)
    private String createTime;

    @TableField(fill = FieldFill.UPDATE)
    private String updateTime;

    // 其他字段...
}

insertFillupdateFill 方法是在执行数据库的插入或更新操作时被调用的

public class BussinessCenterMetaObjectHandler implements MetaObjectHandler {
    
    @Override
    public void insertFill(MetaObject metaObject) {
        // 判断当前实体是否有 createTime 属性的 setter 方法
        boolean createTime = metaObject.hasSetter("createTime");
        if (createTime) {
            // 判断 createTime 字段的值是否为 null
            if (this.getFieldValByName("createTime", metaObject) == null) {
                // 使用 strictInsertFill 方法为 createTime 字段填充默认值
                this.strictInsertFill(metaObject, "createTime", Date.class, new Date());
            }
        }
    }
    
    @Override
    public void updateFill(MetaObject metaObject) {
        boolean updateUserId = metaObject.hasSetter("updateUserId");
        if(updateUserId){
            this.strictUpdateFill(metaObject,"updateUserId",Long.class,SecurityUtil.getUserId());
        }
        boolean updateTime = metaObject.hasSetter("updateTime");
        if(updateTime){
            this.strictUpdateFill(metaObject,"updateTime",Date.class,new Date());
        }
    }

    
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值