有些时候我们可能会有这样的需求,插⼊或者更新数据时,希望有些字段可以⾃动填充数据,⽐如密码、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注解