在我们项目的开发中,当我们在修改数据库中的某些值的时候,有一些字段属于公共子段,就是有些字段不仅是在某一个表里有,而是好几张表里面都要设置这些字段。
为了简化项目的开发,缩小代码量,我们就可以使用mybatis Plus为我们提供的公共字段填充功能,使我们的开发更有效率,没必要把时间和代码量花费在这些重复的工作上。
举个例子:
在我们很多表里面可能会有这样的字段:“createTime”、“createUser”、“updateTime”、“updateUser”等等。这些字段在很多表里都会有,用来记录我们添加或者修改的时间和操作人。这种字段就属于公共字段。
使用步骤:
1、在我们的公共字段上面,使用“@TableFile”标签,在标签后面填上值,看本字段是添加时需要填充还是在修改时要填充。
@TableField(fill = FieldFill.INSERT) //插入时填充字段
private LocalDateTime createTime;
@TableField(fill = FieldFill.INSERT_UPDATE)//插入和更新时填充字段
private LocalDateTime updateTime;
@TableField(fill = FieldFill.INSERT)//插入时填充字段
private Long createUser;
@TableField(fill = FieldFill.INSERT_UPDATE)//插入和更新时填充字段
private Long updateUser;
2、编写一个类,需要实现 MetaObjectHandler 接口,在实现接口之后,我们需要实现此接口的两个方法 insertFile 和 updateFile
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
metaObject.setValue("createTime", LocalDateTime.now());
metaObject.setValue("updateTime",LocalDateTime.now());
metaObject.setValue("createUser",new Long(1));
metaObject.setValue("updateUser",new Long(1));
}
@Override
public void updateFill(MetaObject metaObject) {
metaObject.setValue("updateTime",LocalDateTime.now());
metaObject.setValue("updateUser",new Long(1));
}
类名可以随意取,但是建议取一个能一眼看出来作用的名字
3、在实现了 MetaObjectHandler 接口的类上加上 @Component 标签,将我们的类交给Spring来管理就可以了
在后面的开发中,这几个公共字段我们就不用自己设置了,系统会自动给我们设置,能节省我们时间和代码量
版权声明:本文为weixin_61724992原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。