MyBatis-Plus自动填充功能

本文介绍了如何在使用MyBatis-Plus时,为数据库表的通用字段如创建时间和创建人等设置自动填充功能。在插入和更新操作时,create_time和create_by字段能自动获取当前时间及操作人信息,提升开发效率。参照MyBatis-Plus官方文档,可以轻松配置这一特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

场景

最近公司用MyBatis-Plus,跟MyBatis差不多,感觉封装的更多一些。

其中碰到一个场景,就是DB表有一些通用通过字段,比如创建时间,创建人,更新时间,更新人等,想要在插入的时候自动填充

create_time,create_by插入时自动填充

update_time,update_by更新时自动填充

自动填充功能

要实现上述功能可以直接参考官网:自动填充功能 | MyBatis-Plus

### MyBatis-Plus 自动填充 功能详解 #### 实现自动填充的关键组件 MyBatis-Plus 提供了 `MetaObjectHandler` 接口来实现字段的自动填充功能。通过继承该接口并重写相应的方法,可以在插入或更新操作时自动生成特定字段的值[^2]。 ```java import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler; import org.apache.ibatis.reflection.MetaObject; public class MyMetaObjectHandler implements MetaObjectHandler { @Override public void insertFill(MetaObject metaObject) { this.strictInsertFill(metaObject, "createTime", Date::new); // 插入时填充创建时间 this.strictInsertFill(metaObject, "createBy", () -> getUserId(), Long.class); // 填充创建者ID } @Override public void updateFill(MetaObject metaObject) { this.strictUpdateFill(metaObject, "updateTime", Date::new); // 更新时填充修改时间 this.strictUpdateFill(metaObject, "updateBy", () -> getUserId(), Long.class); // 填充修改者ID } } ``` #### 字段配置方式 为了使某个字段能够被自动填充,在对应的实体类中需要使用 `@TableField` 注解,并指定 `fill` 属性为合适的枚举值(如 `FieldStrategy.NOT_NULL` 或其他策略)。这允许框架识别哪些字段应该参与自动填充逻辑[^3]。 ```java @TableField(fill = FieldFill.INSERT) private Date createTime; // 创建时间 @TableField(fill = FieldFill.UPDATE) private Date updateTime; // 修改时间 ``` #### 启用全局处理器 最后一步是在 Spring Boot 应用程序上下文中注册上述处理程序作为 Bean 组件,从而让整个应用程序都能享受到这一特性带来的便利[^1]。 ```yaml mybatis-plus: global-config: db-config: id-type: auto configuration: handlers: - my.package.MyMetaObjectHandler ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值