有些时候我们可能会有这样的需求,插⼊或者更新数据时,希望有些字段可以⾃动填充数据,⽐如密码、version等。在MP中提供了这样的功能,可以实现⾃动填充。

1、添加@TableField注解

@TableField(fill = FieldFill.INSERT) //插⼊数据时进⾏填充
private String version;

为email添加⾃动填充功能,在新增数据时有效。

FieldFill提供了多种模式选择:

 public enum FieldFill {
        /**
         * 默认不处理
         */
        DEFAULT,
        /**
         * 插⼊时填充字段
         */
        INSERT,
        /**
         * 更新时填充字段
         */
        UPDATE,
        /**
         * 插⼊和更新时填充字段
         */
        INSERT_UPDATE
    }

2、编写MyMetaObjectHandler

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    
    @Override
    public void insertFill(MetaObject metaObject) {

        Object version = getFieldValByName("version", metaObject);
        if(null == version){
            // 该属性为空,可以进行填充
            setFieldValByName("version",1,metaObject);
        }

    }

    @Override
    public void updateFill(MetaObject metaObject) {

    }
}

测试:

这个时候我们向数据库插入数据,即使没有指定version数据,但是在执行的过程中,它也会默认往数据库中的version字段中设置值。

3、注意事项

  • 填充原理是直接给entity的属性设置值
  • 注解则是指定该属性在对应的情况下必有值,如果无值则入库会是null
  • MetaObjectHandler提供的默认方法的策略均为:如果属性有值则不会覆盖,如果填充为null则不填充
  • 字段必须声明TableField注解,属性fill选择对应的策略,该声明告知MybatisPlus需要预留注入sql字段
  • 填充处理器MyMetaObjectHandler在springboot中需要声明@Component或者@Bean注解

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐