Mybatis-Plus更新时间字段不生效的解决

 更新时间:2024年09月22日 09:47:06   作者:Jerryean99  
在使用Mybatis-Plus时,可能会遇到updateTime字段不自动更新的问题,通过分析,原因在于selectById获取旧数据后,如果字段已有值,更新操作不会自动填充更新时间,可以通过直接在实体中设置更新时间或在更新操作时指定时间来解决此问题

背景

Mybatis-Plus是在Mybatis的基础上只做增强不做改变,主要是为简化开发。项目的背景是使用的就是Mybatis-Plus,但是在运行项目过程中发现一个问题,当使用Mybatis-Plus进行数据的更新的时候,更新字段没有按照我们所预想的进行对应的时间的更新。

创建这个字段的语句如下所示:

 `update_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间'

原因分析

使用Mybatis-Plus的更新方法,进行对应数据实体的更新,比如使用如下方法:

XXX.updateById()
// ....... 等等方法

这些方法使用之后,发现没有对updateTime字段数据进行更新。

原因分析:

当selectByld从数据库取出旧数据,然后修改自己想修改的字段后调用updateById,会发现updateTime字段不会更新,这是因为selectByld可以取出updateTime的旧值,更新时填充策路会判断属性已有值,不进行自动填充,因此updateTime不会自动更新。而且官方目前没有直接提供强制更新的方法。

查看fillStrategy方法源码,我们也可以看到只有属性没有被填充值,才会执行set方法。

解决办法

解决方法一

更新时设置更新时间

	TDZopenOrder openOrder = openOrderService.getById(orderId);
	openOrder.setOrderId(washOrderId);
	openOrder.setUpdateTime(LocalDateTime.now());
	openOrder.updateById()

解决方法二

实体上设置更新时间

	public class TDZopenOrder {
	    @ApiModelProperty("更新时间")
	    @TableField(update = "now()")
	    private LocalDateTime updateTime;
	}

推荐使用方法二,这样不用每次都取设置更新时间,简化代码!!!

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 如何解决IDEA.properties文件中文乱码问题

    如何解决IDEA.properties文件中文乱码问题

    这篇文章主要介绍了如何解决IDEA.properties文件中文乱码问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Spring实现定时任务的两种方法详解

    Spring实现定时任务的两种方法详解

    Spring提供了两种方式实现定时任务,一种是注解,还有一种就是接口了,这篇文章主要为大家介绍了这两种方法的具体实现方法,需要的可以参考下
    2024-12-12
  • Spring中@ExceptionHandler注解的工作原理详解

    Spring中@ExceptionHandler注解的工作原理详解

    这篇文章主要介绍了Spring中@ExceptionHandler注解的工作原理详解,Spring Web注解@ExceptionHandler可以用来指定处理某类异常的控制器方法,从而在这些异常发生时,会有相应的控制器方法来处理此类异常,需要的朋友可以参考下
    2024-01-01
  • 聊聊Object类中的wait()和notify()方法

    聊聊Object类中的wait()和notify()方法

    这篇文章主要介绍了Object类中的wait()和notify()方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • Spring Boot整合Thymeleaf详解

    Spring Boot整合Thymeleaf详解

    这篇文章主要介绍了Spring Boot整合Thymeleaf详解,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • SpringBoot 项目使用hutool 工具进行 http 接口调用的处理方法

    SpringBoot 项目使用hutool 工具进行 http 接口调用的处理方

    在实际的开发过程中一个互联网的项目来说 ,有可能会涉及到调用外部接口的实际业务场景,下面通过本文给大家介绍SpringBoot 项目 使用hutool 工具进行 http 接口调用的处理方法,需要的朋友可以参考下
    2022-06-06
  • SpringBoot分离打Jar包的两种配置方式

    SpringBoot分离打Jar包的两种配置方式

    这篇文章主要介绍了SpringBoot分离打Jar包的两种配置方式,方式一是基于maven-jar-plugin,方式二是基于spring-boot-maven-plugin,文中结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • Mybatis MappedStatement类核心原理详解

    Mybatis MappedStatement类核心原理详解

    这篇文章主要介绍了Mybatis MappedStatement类,mybatis的mapper文件最终会被解析器,解析成MappedStatement,其中insert|update|delete|select每一个标签分别对应一个MappedStatement
    2022-11-11
  • Java  队列实现原理及简单实现代码

    Java 队列实现原理及简单实现代码

    这篇文章主要介绍了Java 队列实现原理及简单实现代码的相关资料,需要的朋友可以参考下
    2016-10-10
  • Spring Boot应用配置常用相关视图解析器详解

    Spring Boot应用配置常用相关视图解析器详解

    这篇文章主要给大家介绍了关于Spring Boot应用配置常用相关视图解析器的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-12-12

最新评论