解决Mybatis plus字段填充不覆盖原有值问题

问题

项目自定义了MpMetaObjectHandler填充策略,对插入时间和更新时间自动填充。

做业务的时候要求数据更新的时候更新时间需要同步到最新时间。

问题就出现了: 自动填充策略不能填充已存在值的字段。

原因

查找Mybatis plus 指南,定位到问题。
在这里插入图片描述

  • 当要填充的值为null时,字段不给予填充。
  • 当要填充的字段已存在值的情况,不给予填充。

撸一下源码看看:

在这里插入图片描述

解决

从源码中看到metaObject.getValue(fieldName)为null时才进行填充。从自定义填充策略的方法不难看出metaObject是我们要保存的数据。
在这里插入图片描述
那么只要在执行这句判断的时候吧metaObject的字段值设置为null就行了

在这里插入图片描述
测试可行!

### 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 将会依据所定义的行为自动为相应的时间戳字段,从而简化开发流程并减少潜在错误的发生几率。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值