Mybatis公共字段自动填充配置

本文介绍了如何使用Java实现自动字段填充功能,通过`MyMetaObjectHandler`类覆盖`insertFill`和`updateFill`方法,自动设置创建时间和更新时间等公共字段。实体类中使用@TableField注解配合FieldFill枚举来指定字段在插入或更新时的填充策略。示例展示了Employee实体类中如何应用这些注解。

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

1、配置类

@Component
@Slf4j
public class MyMetaObjectHandler implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        log.info("公共字段自动填充【insert】");
        log.info(metaObject.toString());
        metaObject.setValue("createTime", LocalDateTime.now());
        metaObject.setValue("updateTime", LocalDateTime.now());
        metaObject.setValue("createUser", BaseContext.getCurrentId());
        metaObject.setValue("updateUser", BaseContext.getCurrentId());
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        metaObject.setValue("updateTime", LocalDateTime.now());
        metaObject.setValue("updateUser", BaseContext.getCurrentId());
    }
}

2、在对应的实体类中添加自动填充注解

@TableField(fill = FieldFill.INSERT)  // 新增时有效
@TableField(fill = FieldFill.INSERT_UPDATE) // 新增或更新时有效

例子:

@Data
public class Employee implements Serializable {

    private static final long serialVersionUID = 1L;

    private Long id;

    private String username;

    private String name;

    private String password;

    private String phone;

    private String sex;

    private String idNumber;

    private Integer status;

    @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;

}

### MyBatis 中实现公共字段自动填充 在传统 MyBatis 开发中,为了实现在每次插入或更新记录时自动设置某些公共字段(如 `create_time` 和 `update_time`),通常需要手动编写 SQL 或者借助拦截器来完成这一操作。然而,在引入 MyBatis-Plus 后,可以更加便捷地通过内置机制实现这些需求。 #### 使用 MyBatis-Plus 自动填充功能 MyBatis-Plus 提供了一种简单的方式来处理实体类中的时间戳和其他通用属性的自动化管理。具体来说: - **定义实体类**:首先应当确保实体对象中有对应的字段用于存储创建时间和修改时间,并标记相应的注解以便框架识别[^1]。 ```java import com.baomidou.mybatisplus.annotation.TableField; import java.util.Date; public class User { private Long id; @TableField(fill = FieldFill.INSERT) private Date createTime; // 创建时间 @TableField(fill = FieldFill.UPDATE) private Date updateTime; // 更新时间 } ``` - **配置处理器**:接着需注册一个元数据对象处理器 (`MetaObjectHandler`) 来指定具体的逻辑,比如当前日期作为默认值填入上述两个字段内。 ```java import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler; import org.apache.ibatis.reflection.MetaObject; import java.util.Date; @Component public class MyMetaObjectHandler implements MetaObjectHandler { @Override public void insertFill(MetaObject metaObj) { this.strictInsertFill(metaObj, "createTime", Date.class, new Date()); } @Override public void updateFill(MetaObject metaObj) { this.strictUpdateFill(metaObj, "updateTime", Date.class, new Date()); } } ``` - **项目配置文件调整**:对于基于 Spring Boot 的应用而言,还需要适当调整 application.yml 文件以支持数据库连接及其他必要的参数设定[^2]。 ```yaml server: port: 8081 spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/testdb?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&serverTimezone=GMT%2B8 username: root password: yourpasswordhere ``` 以上步骤完成后,每当执行新增或编辑操作时,MyBatis-Plus 将会依据所定义的行为自动为相应的时间戳字段赋值,从而简化开发流程并减少潜在错误的发生几率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值