MyBatis-Plus实现自动填充createTime和updateTime
数据库的表中需要创建时间和修改时间字段时,常规的做法是:
1、在数据库操作
Navicat可视化界面

create_time:

update_time:

sql语句为:
CREATE TABLE `smart-admin-dev`.`Untitled` (
`id` int(0) NOT NULL AUTO_INCREMENT,
`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 87 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci ROW_FORMAT = Dynamic;
2、在代码中进行相关操作的时候手动设置。
MyBatis-Plus提供了自动填充功能
链接:https://mp.baomidou.com/guide/auto-fill-metainfo.html
原理:
实现元对象处理器接口:com.baomidou.mybatisplus.core.handlers.MetaObjectHandler
注解填充字段 生成器策略部分也可以配置!
步骤:
(1)在实体类中标记为填充字段
用法:
public class User {
// 注意!这里需要标记为填充字段
@TableField(.. fill = FieldFill.INSERT)
private String fillField;
....
}
public class User {
/**
* 创建时间
*/
@TableField(fill = FieldFill.INSERT)
private Date createTime;
/**
* 更新时间
*/
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;
....
}
(2)自定义实现类 MyMetaObjectHandler
用法:
@Slf4j
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
log.info("start insert fill ....");
this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐使用)
// 或者
this.strictUpdateFill(metaObject, "createTime", () -> LocalDateTime.now(), LocalDateTime.class); // 起始版本 3.3.3(推荐)
// 或者
this.fillStrategy(metaObject, "createTime", LocalDateTime.now()); // 也可以使用(3.3.0 该方法有bug)
}
@Override
public void updateFill(MetaObject metaObject) {
log.info("start update fill ....");
this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐)
// 或者
this.strictUpdateFill(metaObject, "updateTime", () -> LocalDateTime.now(), LocalDateTime.class); // 起始版本 3.3.3(推荐)
// 或者
this.fillStrategy(metaObject, "updateTime", LocalDateTime.now()); // 也可以使用(3.3.0 该方法有bug)
}
}
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
// 属性名称,不是字段名称
this.setFieldValByName("createTime",new Date(),metaObject);
this.setFieldValByName("updateTime",new Date(),metaObject);
}
@Override
public void updateFill(MetaObject metaObject) {
this.setFieldValByName("updateTime",new Date(),metaObject);
}
}
注意事项:
填充原理是直接给的属性设置值!!!
注解则是指定该属性在对应情况下必有值,如果无值则入库会是
提供的默认方法的策略均为:如果属性有值则不覆盖,如果填充值为则不填充
字段必须声明注解,属性选择对应策略,该声明告知需要预留注入字段
填充处理器在 Spring Boot 中需要声明或注入
要想根据注解和以及来区分必须使用父类的或者方法
不需要根据任何来区分可以使用父类的方法