当前位置: 首页 > wzjs >正文

阿里云营销网站建设德州网站制作公司

阿里云营销网站建设,德州网站制作公司,用织梦做网站,0资本建设网站✅ MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案 前言一、问题现象二、原因分析1. 使用了 strictInsertFill/strictUpdateFill 导致更新失效2. 实体类注解配置错误3. MetaObjectHandler 未生效4. 使用自定义 SQL 导致自动填充失效5. 字段类型不匹配 三、…

✅ MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案

  • 前言
  • 一、问题现象
  • 二、原因分析
    • 1. 使用了 `strictInsertFill/strictUpdateFill` 导致更新失效
    • 2. 实体类注解配置错误
    • 3. `MetaObjectHandler` 未生效
    • 4. 使用自定义 SQL 导致自动填充失效
    • 5. 字段类型不匹配
  • 三、总结:常见原因与解决方法对照表
  • 四、推荐写法


前言

在使用 MyBatis Plus 时,通常我们会在数据库表中设置 create_timeupdate_time 两个字段,借助 MyBatis Plus 的 自动填充功能 来维护这些时间字段。

但是,有时候你可能会遇到 update_time 字段未自动更新的情况,哪怕代码中已经配置了 MetaObjectHandler。本文将针对这一问题,分析可能的原因,并提供详细的解决方案。


一、问题现象

假设我们有如下的 updateFill() 方法:

@Override
public void updateFill(MetaObject metaObject) {log.info("执行更新填充...");this.strictInsertFill(metaObject, "updateTime", Timestamp.class, Timestamp.valueOf(LocalDateTime.now())); this.strictInsertFill(metaObject, "updateBy", BigInteger.class, userId); 
}

但是执行更新操作后:

  • 数据库中的 update_time 字段未更新

  • 没有报错,但 updateTime 依然是旧值

  • updateBy 可能也未更新

接下来我们来分析可能的原因。


二、原因分析

1. 使用了 strictInsertFill/strictUpdateFill 导致更新失效

  • 原因:

    strictInsertFill/strictUpdateFill 主要用于插入数据时的自动填充。即使在 updateFill() 中使用它,也不会生效。

  • 原理解释:

    strictInsertFill/strictUpdateFill 的作用是 如果字段已有值则不会覆盖,而在更新场景中,一般实体对象中 update_time 已有值。

  • 解决方案:

    strictInsertFill/strictUpdateFill 替换为 setFieldValByName

    @Override
    public void updateFill(MetaObject metaObject) {log.info("start update fill ....");this.setFieldValByName("updateTime", Timestamp.valueOf(LocalDateTime.now()), metaObject);this.setFieldValByName("updateBy", userId, metaObject);
    }
    
  • 原因分析补充:

    • strictInsertFill/strictUpdateFill插入/更新数据时填充,不适用于更新场景。

    • setFieldValByName → 更新数据时直接覆盖字段值,即使原值存在。


2. 实体类注解配置错误

  • 原因:

    实体类中的字段没有正确标注 @TableField(fill = FieldFill.INSERT_UPDATE),导致自动填充机制无法生效。

  • 解决方案:

    在实体类中正确设置注解:

    import com.baomidou.mybatisplus.annotation.FieldFill;
    import com.baomidou.mybatisplus.annotation.TableField;
    import lombok.Data;
    import java.time.LocalDateTime;@Data
    public class User {private Long id;private String name;@TableField(fill = FieldFill.INSERT)private LocalDateTime createTime;@TableField(fill = FieldFill.INSERT_UPDATE)private LocalDateTime updateTime;@TableField(fill = FieldFill.INSERT_UPDATE)private BigInteger updateBy;
    }
    
  • 注意:

    • FieldFill.INSERT_UPDATE:用于插入和更新时自动填充。

    • 如果没有加上这个注解,MyBatis Plus 不会执行自动填充逻辑。

3. MetaObjectHandler 未生效

  • 原因:

    MetaObjectHandler 需要被 Spring 管理。如果没有加上 @Component 注解或没有被扫描到,自动填充方法不会执行。

  • 解决方案:

    确保 FieldAutoFillHandler 类上有 @Component 注解:

    import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
    import lombok.extern.slf4j.Slf4j;
    import org.apache.ibatis.reflection.MetaObject;
    import org.springframework.stereotype.Component;@Slf4j
    @Component
    public class FieldAutoFillHandler implements MetaObjectHandler {@Overridepublic void insertFill(MetaObject metaObject) {log.info("执行插入填充...");this.setFieldValByName("createTime", LocalDateTime.now(), metaObject);this.setFieldValByName("updateTime", LocalDateTime.now(), metaObject);}@Overridepublic void updateFill(MetaObject metaObject) {log.info("执行更新填充...");this.setFieldValByName("updateTime", LocalDateTime.now(), metaObject);}
    }
    
  • 注意:

    如果项目中有多个 MetaObjectHandler,需要确保不会有冲突。

4. 使用自定义 SQL 导致自动填充失效

  • 原因:

    如果你在 Mapper.xml 中自定义了 update 语句,那么 MyBatis Plus 不会触发自动填充逻辑。

  • 解决方案:

    • 方法 1:在 XML 中手动设置 update_time 字段:

      <update id="updateUser" parameterType="com.example.entity.User">UPDATE userSET name = #{name},update_time = NOW(),update_by = #{updateBy}WHERE id = #{id}
      </update>
      
    • 方法 2:直接使用 BaseMapper 提供的 updateById() 等方法,MyBatis Plus 会自动触发填充:

      User user = userMapper.selectById(1L);
      user.setName("李四");
      userMapper.updateById(user);
      

5. 字段类型不匹配

  • 原因:

    数据库中 update_time 的数据类型与 Java 实体类的类型不匹配,导致填充失败。

  • 解决方案:

    确保数据库字段类型和实体类一致:

    ALTER TABLE user
    MODIFY update_time TIMESTAMP NULL DEFAULT NULL;
    
    private LocalDateTime updateTime;
    
  • 注意:

    • 使用 LocalDateTime 处理时间字段是最佳实践。

    • 如果数据库字段为 datetimetimestamp,不要使用 String 类型。

三、总结:常见原因与解决方法对照表

原因现象解决方法
使用了 strictInsertFillupdate_time 未更新使用 setFieldValByName 替代
实体类注解错误自动填充无效确保字段上加了 @TableField(fill = FieldFill.INSERT_UPDATE)
MetaObjectHandler 未生效updateFill() 不执行确保加上 @Component 注解
使用自定义 SQL 覆盖了默认方法填充逻辑未触发使用 BaseMapper.updateById() 或在 SQL 中手动填充
数据类型不匹配字段更新失败数据库字段使用 timestamp 且实体类使用 LocalDateTime

四、推荐写法

最终推荐的 updateFill() 写法如下:

@Override
public void updateFill(MetaObject metaObject) {log.info("执行更新填充...");this.setFieldValByName("updateTime", LocalDateTime.now(), metaObject);this.setFieldValByName("updateBy", userId, metaObject);
}

通过这种方式,确保 update_time 字段在更新时自动更新,同时避免了不必要的填充失效问题。


文章转载自:

http://1UIxexAb.bLbys.cn
http://1sExUsXZ.bLbys.cn
http://PSm3Ic6w.bLbys.cn
http://DkMghuiI.bLbys.cn
http://OZUGxWLY.bLbys.cn
http://Bno7yFSe.bLbys.cn
http://7r0Xt34q.bLbys.cn
http://G9axp5wJ.bLbys.cn
http://79gtbPII.bLbys.cn
http://xQTlDhFC.bLbys.cn
http://AdSBi7O0.bLbys.cn
http://VpgJdMNZ.bLbys.cn
http://r6A0ucHz.bLbys.cn
http://2Mh2EGJx.bLbys.cn
http://s6AZu8S2.bLbys.cn
http://xo1wqsDk.bLbys.cn
http://lHCfXQY3.bLbys.cn
http://6kRemE5A.bLbys.cn
http://AiZVaaIg.bLbys.cn
http://1w5uuL6g.bLbys.cn
http://IxVbs9Xf.bLbys.cn
http://y7qmewuz.bLbys.cn
http://cY3kUJ51.bLbys.cn
http://ZaKqK39V.bLbys.cn
http://31LyAB1o.bLbys.cn
http://k19XALNj.bLbys.cn
http://sAFEGeRX.bLbys.cn
http://mgP89USs.bLbys.cn
http://xxVdpzNF.bLbys.cn
http://pQMw1CaY.bLbys.cn
http://www.dtcms.com/wzjs/773202.html

相关文章:

  • 中标建设集团有限公司 网站前端 网站开发 常见功能实现
  • 北京外贸网站建设公司网站添加关键词
  • 重庆市住建厅网站网页开发工资多少
  • 门户网站代码怎么登陆wordpress后台
  • 佛山购物网站建设松江移动网站建设
  • 自助微信网站遂宁市城市建设档案馆网站
  • 网站建设公司现在还挣钱吗个人网站怎么做联盟推广
  • 网站开发培训机构需要多少钱东莞网站设计智能 乐云践新
  • 中国建设银行安徽分行网站python 做网站开发吗
  • 半江红网站建设赤峰建设业协会的官方网站
  • 水利建设管理司网站wordpress导出导入
  • vue做网站的实例手机网站一定要与pc网站一样
  • 网站建设实施步骤移动互联网开发前景
  • spa.net网站开发模板网生产线
  • 网站seo分析常用的工具是宁波网站优化软件
  • 网站优化怎样的微信头像定制软件
  • 如何做网站赚流量钱如何让百度收录网站
  • 天津seo公司网站站群管理系统
  • 投简历找工作哪个网站好推荐佛山顺德网站建设
  • 网站运营管理的内容有哪些个人网站制作多少钱
  • 网站建设有哪些岗位职责wordpress 数据表
  • 医院网站建设价格长沙网站建设联系电话
  • 网上购物网站网站建设分析秦皇岛建设局局官方网站
  • 中山快速做网站费用域名备案注销流程
  • 中文域名网站链接无法打开p2p借贷网站开发 论文
  • 网站服务器参数查询免费域名空间哪个好
  • 做g3云推广需要网站商家在携程旅游网站怎样做宣传
  • 汕头网站建设科技有限公司wordpress前台文章
  • 建网站费用记账开网店在线咨询
  • 做网站的企业广州公众号软文范例100