07_通过 Mybatis 自动填充记录的创建时间和更新时间

07_通过 MyBatis-Plus 自动填充记录的创建时间和更新时间

在使用 MyBatis-Plus 进行数据库操作时,自动填充字段(如创建时间和更新时间)是一项非常常见的需求。本文将展示如何通过 MyBatis-Plus 实现对 createTimeupdateTime 字段的自动填充。

1. 定义 DO 类

首先,我们需要在 DO(数据对象)类中定义 createTimeupdateTime 字段,并通过注解指定其自动填充策略。

java 复制代码
@Data
public class BaseDO {

    @TableField(value = "create_time", fill = FieldFill.INSERT)
    private LocalDateTime createTime;

    @TableField(value = "update_time", fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updateTime;
}

在上面的代码中:

  • @TableField 注解用来指定字段对应的数据库列名和自动填充策略。
  • FieldFill.INSERT 表示在插入数据时自动填充该字段。
  • FieldFill.INSERT_UPDATE 表示在插入和更新数据时都自动填充该字段。

2. MyBatis-Plus 自动填充配置类

接下来,我们需要配置 MyBatis-Plus 的自动填充功能,这需要实现 MetaObjectHandler 接口,并重写 insertFillupdateFill 方法。

java 复制代码
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.time.LocalDateTime;

/**
 * MyBatis-Plus 自动填充配置类。
 */
@Configuration
public class MyBatisPlusConfig implements MetaObjectHandler {

    /**
     * 配置 MyBatis-Plus 插件,包括分页插件。
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        // 添加分页插件,支持 MySQL 数据库
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }

    /**
     * 插入时自动填充创建时间和更新时间。
     */
    @Override
    public void insertFill(MetaObject metaObject) {
        LocalDateTime now = LocalDateTime.now();
        // 严格插入时填充字段
        this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, now);
        this.strictInsertFill(metaObject, "updateTime", LocalDateTime.class, now);
    }

    /**
     * 更新时自动填充更新时间。
     */
    @Override
    public void updateFill(MetaObject metaObject) {
        // 严格更新时填充更新时间
        this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());
    }
}

在配置类中:

  • insertFill 方法会在插入数据时自动填充 createTimeupdateTime 字段。
  • updateFill 方法会在更新数据时自动填充 updateTime 字段。
相关推荐
星光一影5 小时前
教育培训机构消课管理系统智慧校园艺术舞蹈美术艺术培训班扣课时教务管理系统
java·spring boot·mysql·vue·mybatis·uniapp
cike_y11 小时前
Mybatis之作用域(Scope)和生命周期-解决属性名和字段名不一致的问题&ResultMap结果集映射
java·开发语言·数据库·tomcat·mybatis
柒.梧.12 小时前
MyBatis一对一关联查询深度解析:大实体类、SQL99联表、分布式查询实践
分布式·mybatis
Coder_Boy_15 小时前
SpringAI与LangChain4j的智能应用-(理论篇)
人工智能·spring·mybatis·springai·langchain4j
zhoupenghui16815 小时前
项目访问接口时报“MISCONF Redis is configured to save RDB snapshots, ...“错误的解决方案
数据库·redis·mybatis
cike_y1 天前
Mybatis之解析配置优化
java·开发语言·tomcat·mybatis·安全开发
勇往直前plus1 天前
MyBatis/MyBatis-Plus类型转换器深度解析:从基础原理到自定义实践
数据库·oracle·mybatis
古城小栈1 天前
Spring Boot 数据持久化:MyBatis-Plus 分库分表实战指南
spring boot·后端·mybatis
无名-CODING1 天前
SQL 注入指南
sql·mybatis
shuair1 天前
redis缓存双写
redis·缓存·mybatis