mybatis-plus属性填充

本文介绍如何使用MyBatis-Plus实现字段自动填充功能,通过实现元数据处理接口并在字段上添加注解来简化对create和update相关字段的操作。

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

mybatis-plus属性填充

应用场景

实际开发过程中, 数据库表设计经常需要create和update相关的字段, 如createUserId, createTime, updateUserId, updateTime等, 对于create相关的字段只需要创建的时候赋值即可, 而update相关的字段每次更新都需要重新赋值, 如果直接写在代码里会增加很多无用的代码, 这时候可以通过mybatis-plus的填充属性功能实现

mybatis-plus填充属性官方文档

https://baomidou.com/pages/4c6bcf/

具体使用

  • 实现元数据处理接口

    1. inserFill()方法用于插入时对公共字段的填充, updateFill()方法用于更新时对公共字段的填充
    2. 项目中userId和userName都是通过接口参数传递, 我将它们设置到ThreadLocal变量中方便提取
    @Component
    public class FieldFillHandler implements MetaObjectHandler {
    
        @Override
        public void insertFill(MetaObject metaObject) {
    
            this.setFieldValByName("createTime", new Date(System.currentTimeMillis()), metaObject);
            this.setFieldValByName("updateTime", new Date(System.currentTimeMillis()), metaObject);
            // 项目中使用的userId和userName
            Map<String, String> contextMap = RequestHeaderHolder.getContextMap();
            if (!CollectionUtils.isEmpty(contextMap)) {
                this.setFieldValByName("createUserId", contextMap.get(RequestHeaderHolder.USER_IDENTITY), metaObject);
                this.setFieldValByName("createUserName", contextMap.get(RequestHeaderHolder.USER_NAME), metaObject);
                this.setFieldValByName("updateUserId", contextMap.get(RequestHeaderHolder.USER_IDENTITY), metaObject);
                this.setFieldValByName("updateUserName", contextMap.get(RequestHeaderHolder.USER_NAME), metaObject);
            }
        }
    
        @Override
        public void updateFill(MetaObject metaObject) {
            this.setFieldValByName("updateTime", new Date(System.currentTimeMillis()), metaObject);
            // 获取userId和userName
            Map<String, String> contextMap = RequestHeaderHolder.getContextMap();
            if (!CollectionUtils.isEmpty(contextMap)) {
                this.setFieldValByName("updateUserId", contextMap.get(RequestHeaderHolder.USER_IDENTITY), metaObject);
                this.setFieldValByName("updateUserName", contextMap.get(RequestHeaderHolder.USER_NAME), metaObject);
            }
        }
    
  • 在需要填充的字段上添加注解

    @ApiModelProperty(value = "创建人id")
    @TableField(fill = FieldFill.INSERT)
    private String createUserId;
    
    @ApiModelProperty(value = "创建人")
    @TableField(fill = FieldFill.INSERT)
    private String createUserName;
    
    @ApiModelProperty(value = "创建时间")
    @TableField(fill = FieldFill.INSERT)
    private Date createTime;
    
    @ApiModelProperty(value = "修改人id")
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private String updateUserId;
    
    @ApiModelProperty(value = "修改人")
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private String updateUserName;
    
    @ApiModelProperty(value = "修改时间")
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;
    

    其中FieldFill枚举包含如下:

    public enum FieldFill {
        /**
         * 默认不处理
         */
        DEFAULT,
        /**
         * 插入填充字段
         */
        INSERT,
        /**
         * 更新填充字段
         */
        UPDATE,
        /**
         * 插入和更新填充字段
         */
        INSERT_UPDATE
    }
    
### 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、付费专栏及课程。

余额充值