Java + Mybatis Plus 实现自动填充字段

注: 主要用于在插入和更新操作时自动填充字段(如创建时间、更新时间等)。它适用于 MyBatis-Plus 的 Mapper 接口和 XML 映射文件 ,但不适用于原生 SQL 写法(如 JDBC、JPA 或直接 SQL 语句)。

自动填充 handler

在项目/global/handler 目录下创建 MyMetaObjectHandler.java

java 复制代码
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;

import java.time.LocalDateTime;

@Component // 必须加上 @Component 注解,让 Spring 管理
public class MyMetaObjectHandler implements MetaObjectHandler {

    // 插入时自动填充
    @Override
    public void insertFill(MetaObject metaObject) {
        // 方法一:指定字段名
        // this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐)

        // 方法二:使用注解方式(更灵活,推荐)
        // this.fillStrategy(metaObject, "createTime"); // 也可以使用这种方式,但需要配合注解

        // 方法三:通用方式,检查字段是否存在再填充
        if (metaObject.hasSetter("createTime")) {
            this.setFieldValByName("createTime", LocalDateTime.now(), metaObject);
        }
//        // 可以添加其他需要在插入时填充的字段,例如 creator
//        if (metaObject.hasSetter("creator")) {
//            this.setFieldValByName("creator", "SYSTEM", metaObject); // 示例:用 SYSTEM 填充
//        }
    }

    // 更新时自动填充
    @Override
    public void updateFill(MetaObject metaObject) {
        // 更新时填充 updateTime
        if (metaObject.hasSetter("updateTime")) {
            this.setFieldValByName("updateTime", LocalDateTime.now(), metaObject);
        }
//        // 可以添加其他需要在更新时填充的字段,例如 updator
//        if (metaObject.hasSetter("updator")) {
//            this.setFieldValByName("updator", "SYSTEM", metaObject); // 示例:用 SYSTEM 填充
//        }
    }
}

BaseBean

pojo 集成 BaseBean。在项目/model/pojo 目录下创建 BaseBean.java

java 复制代码
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.TableField;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateTimeDeserializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateTimeSerializer;
import lombok.Data;

import java.time.LocalDateTime;

@Data
public class BaseBean {
    @TableField(fill = FieldFill.INSERT)
    private Long createId;

    @TableField(fill = FieldFill.INSERT)
    @JsonDeserialize(using = LocalDateTimeDeserializer.class)
    @JsonSerialize(using = LocalDateTimeSerializer.class)
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    private LocalDateTime createTime;

    @TableField(fill = FieldFill.UPDATE)
    private Long updateId;

    @TableField(fill = FieldFill.UPDATE)
    @JsonDeserialize(using = LocalDateTimeDeserializer.class)
    @JsonSerialize(using = LocalDateTimeSerializer.class)
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    private LocalDateTime updateTime;
}

application.yml

配置文件

yml 复制代码
# MyBatis-Plus 配置
mybatis-plus:
  configuration:
    map-underscore-to-camel-case: true
  mapper-locations: classpath*:mapper/*.xml

依赖引用

xml 复制代码
<!-- MyBatis-Plus 依赖 -->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.2</version> <!-- 请替换为最新版本 -->
</dependency>
相关推荐
提笔了无痕20 分钟前
git基本了解、常用基本命令与使用
git·后端
java1234_小锋44 分钟前
Spring IoC的实现机制是什么?
java·后端·spring
喵个咪1 小时前
开箱即用的 GoWind Admin|风行,企业级前后端一体中后台框架:JWT 集成指南
后端·go
绝不收费—免费看不了了联系我1 小时前
Fastapi的单进程响应问题 和 解决方法
开发语言·后端·python·fastapi
xqqxqxxq1 小时前
背单词软件技术笔记(V2.0扩展版)
java·笔记·python
喵个咪1 小时前
开箱即用的 GoWind Admin|风行,企业级前后端一体中后台框架:OPA 集成指南:从原理到实践
后端·go
消失的旧时光-19432 小时前
深入理解 Java 线程池(二):ThreadPoolExecutor 执行流程 + 运行状态 + ctl 原理全解析
java·开发语言
哈哈老师啊2 小时前
Springboot学生综合测评系统hxtne(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring boot
4311媒体网2 小时前
帝国cms调用文章内容 二开基本操作
java·开发语言·php
Victor3562 小时前
Netty(11) Netty的心跳机制是什么?为什么需要它?
后端