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

Spring Data JPA 实现集成实体对象数据库的创建、修改时间字段自动更新

JPA提供了一种事件监听器的机制,用于SQL审计,通过监听器我们可以很快速地去自动更新创建时间、修改时间,主要步骤如下:

一、创建基础实体,包含了创建和修改时间,然后让其他真正的实体继承该实体,减少重复冗余代码

@MappedSuperclass
@EntityListeners(AuditingEntityListener.class)
@Getter
public class AbstractAuditEntity implements Serializable {@CreatedDate@Column(name = "create_time", nullable = false, updatable = false)private Date createTime;@LastModifiedDate@Column(name = "update_time", nullable = false)private Date updateTime;
}

注意,需要两个注解,MappedSuperclass代表是基础实体,不会创建数据库表,EntityListeners注解启用监听器,我们需要使用的是AuditingEntityListener这个监听器。

同时,CreatedDate、LastModifiedDate代表会在创建和修改时更新时间字段,包括创建时间和修改时间。

二、启用JPA的审计功能

启动类需要加上EnableJpaAuditing注解。

三、修改已有实体类

四、如果已经集成QueryDSL,请重新compile一下:

可以看到会自动加上super相关字段。

五、调试接口查看下效果:

默认createTime和updateTime都会填上,然后我们试下修改:

我们会发现,修改后,更新时间为什么没有发生改变?

原因::JSR 317规范指出,对实体类的生命周期操作,不应该通过EntityManager或Query注解实现,所以Audit无法捕获Query注解产生的更新。例如:

解决方法是,单独更新时间,或通过JPA标准规范更新实体,如下:

最终效果:

可以看到CREATE_TIME和UPDATE_TIME都更新了。

http://www.lryc.cn/news/229826.html

相关文章:

  • Vue3集成json-editor-vue3
  • UML建模语言
  • centos7系统离线安装tcpdump抓包软件、使用教程
  • 划分VOC数据集,以及转换为划分后的COCO数据集格式
  • JAVA基础8:方法
  • 域名反查Api接口——让您轻松查询域名相关信息
  • 果儿科技:打造无代码开发的电商平台、CRM和用户运营系统
  • C++ 并发编程中condition_variable和future的区别
  • 【保姆级教程】Linux安装JDK8
  • 【备忘】ChromeDriver 官方下载地址 Selenium,pyppetter依赖
  • day08_osi各层协议,子网掩码,ip地址组成与分类
  • 微信小程序:tabbar、事件绑定、数据绑定、模块化、模板语法、尺寸单位
  • AR工业眼镜:智能化生产新时代的引领者!!
  • 从0到0.01入门React | 008.精选 React 面试题
  • PP-YOLO: An Effective and Efficient Implementation of Object Detector(2020.8)
  • 4、创建第一个鸿蒙应用
  • Docker - DockerFile
  • 2311rust模式匹配
  • Linux系统软件安装方式
  • React + Antd 自定义Select选择框 全选、清空功能
  • 阿里云国际站:应用实时监控服务
  • 专题知识点-二叉树-(非常有意义的一篇文章)
  • 多路数据写入DDR3/DDR4的两种方法
  • 3 分钟看完 NVIDIA GPU 架构及演进
  • SMART PLC 和S7-1200PLC MODBUSTCP通信速度测试
  • C++文件操作知识点总结
  • 开发vue3 UI组件库,并且发布到NPM
  • 雷达测角原理、测角精度、测角分辨率以及3DFFT角度估计算法汇总
  • 金财数科无代码开发平台:轻松实现电商、CRM、广告推广系统的集成连接
  • JavaWeb篇_09——Tomcat运行过程以及Servlet继承结构