公共字段自动填充-MyBatis-Plus

由于使用了MyBatis-Plus提供的方法操作数据库,所有无法直接使用AOP技术来在mapper方法执行前对公共字段赋值。

在 MyBatis-Plus 中,可以通过实现 MyBatis-Plus 提供的 MetaObjectHandler 接口来实现公共字段的自动填充,比如在插入或更新数据时,自动填充创建时间、更新时间等字段。

实现步骤:

  1. 创建一个类并实现 MetaObjectHandler 接口 该类用于实现自动填充的逻辑。

  2. 配置自动填充字段 在实体类中,通过注解来标识哪些字段需要自动填充。

1. 实现**MetaObjectHandler**接口

创建实现 MetaObjectHandler 的类,该类用于在插入和更新时自动填充字段,比如创建时间、更新时间、创建用户、更新用户等。

java 复制代码
// 标注为Spring组件,使其可以被Spring容器管理
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {

    // 插入时的自动填充策略
    @Override
    public void insertFill(MetaObject metaObject) {
        // 字段自动填充的逻辑,可以判断当前字段是否为空然后进行填充
        
        // 使用strictInsertFill方法填充"createTime"字段,填充类型为LocalDateTime,填充值为当前时间
        this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now()); 
        
        // 使用strictInsertFill方法填充"updateTime"字段,填充类型为LocalDateTime,填充值为当前时间
        this.strictInsertFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now()); 
        
        // 使用strictInsertFill方法填充"createUser"字段,填充类型为Long,填充值为当前用户ID
        this.strictInsertFill(metaObject, "createUser", Long.class, BaseContext.getCurrentId());   
        
        // 使用strictInsertFill方法填充"updateUser"字段,填充类型为Long,填充值为当前用户ID
        this.strictInsertFill(metaObject, "updateUser", Long.class, BaseContext.getCurrentId());   
    }

    // 更新时的自动填充策略
    @Override
    public void updateFill(MetaObject metaObject) {
        // 使用strictUpdateFill方法填充"updateTime"字段,填充类型为LocalDateTime,填充值为当前时间
        this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now()); 
        
        // 使用strictUpdateFill方法填充"updateUser"字段,填充类型为Long,填充值为当前用户ID
        this.strictUpdateFill(metaObject, "updateUser", Long.class, BaseContext.getCurrentId());   
    }
}

解释:

  • insertFill:这个方法在插入数据时会被触发,用于自动填充createTimecreateUserupdateTime等字段。
  • updateFill:这个方法在更新数据时会被触发,用于自动填充updateTimeupdateUser字段。
  • BaseContext.getCurrentId():这是为了获取当前操作用户的ID,可以结合ThreadLocal进行存储与获取。

2. 在实体类中标记需要自动填充的字段

在实体类中的相关字段上使用@TableField注解来声明这些字段需要自动填充。

java 复制代码
// 使用@Data注解自动生成getter、setter、toString、equals和hashCode方法
@Data
public class Employee {

    @TableField(fill = FieldFill.INSERT)  // 在插入时自动填充该字段
    private LocalDateTime createTime; // 创建时间字段,类型为LocalDateTime

    @TableField(fill = FieldFill.INSERT_UPDATE)  // 在插入和更新时自动填充该字段
    private LocalDateTime updateTime; // 更新时间字段,类型为LocalDateTime

    @TableField(fill = FieldFill.INSERT)  // 在插入时自动填充该字段
    private Long createUser; // 创建人ID字段,类型为Long

    @TableField(fill = FieldFill.INSERT_UPDATE)  // 在插入和更新时自动填充该字段
    private Long updateUser; // 更新人ID字段,类型为Long

    // 。。。其他属性略。。。
}

解释:

  • @TableField(fill = FieldFill.INSERT):表示在插入时自动填充该字段,例如 createTimecreateUser
  • @TableField(fill = FieldFill.INSERT_UPDATE):表示在插入和更新时都会自动填充该字段,例如 updateTimeupdateUser

3. 工作原理

  • 当你在执行 save 或者 update 操作时,MyBatis-Plus 会自动调用你实现的 MetaObjectHandler,检查并自动为指定字段填充默认值。
  • 使用 BaseContext.getCurrentId() 是为了获取当前操作的用户ID,配合 ThreadLocal,你可以在拦截器中设置用户ID信息,从而实现每个操作记录都是由特定的用户生成或更新的。

4. 总结

  1. 创建 MetaObjectHandler 实现类,负责自动填充字段逻辑。
  2. 在实体类中通过 @TableField 注解标记需要自动填充的字段。
  3. MyBatis-Plus 提供了 FieldFill.INSERTFieldFill.UPDATEFieldFill.INSERT_UPDATE 来区分字段在插入和更新时的自动填充需求。
相关推荐
隐语SecretFlow21 小时前
隐语SecreFlow SCQL 1.0.0b1 发布:更完善的 SQL 支持与更高效的隐私查询引擎
数据库·sql
熊小猿1 天前
在 Spring Boot 项目中使用分页插件的两种常见方式
java·spring boot·后端
paopaokaka_luck1 天前
基于SpringBoot+Vue的助农扶贫平台(AI问答、WebSocket实时聊天、快递物流API、协同过滤算法、Echarts图形化分析、分享链接到微博)
java·vue.js·spring boot·后端·websocket·spring
ttghgfhhjxkl1 天前
文档搜索引擎搜索模块的索引更新策略:实时增量与全量重建设计
数据库·搜索引擎
老华带你飞1 天前
机器人信息|基于Springboot的机器人门户展示系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·机器人·论文·毕设·机器人门户展示系统
StarRocks_labs1 天前
StarRocks 在 Cisco Webex 的探索与实践
数据库·starrocks·json·存算分离·olap 技术栈
notion20251 天前
Adobe Lightroom Classic下载与安装教程(附安装包) 2025最新版详细图文安装教程
java·数据库·其他·adobe
rengang661 天前
351-Spring AI Alibaba Dashscope 多模型示例
java·人工智能·spring·多模态·spring ai·ai应用编程
楚枫默寒1 天前
mongodb备份脚本(单机+副本集)
数据库
小蒜学长1 天前
springboot酒店客房管理系统设计与实现(代码+数据库+LW)
java·数据库·spring boot·后端