当前位置:首页 > JAVA > 正文内容

JPA报错Row was updated or deleted by another transaction的解决方法

高老师2年前 (2024-03-01)JAVA722
在 JPA 中,当多个事务同时尝试对同一行数据进行更新或删除时,如果其中一个事务已经提交了更改,而另一个事务仍在基于旧数据进行操作,JPA 会抛出“Row was updated or deleted by another transaction”异常。
这个异常是由 JPA 抛出的,而非数据库本身。JPA 在执行操作时,会使用乐观锁机制来检测并发访问冲突。乐观锁的工作原理是通过比较版本号来判断数据是否被其他事务修改。每次更新操作都会将版本号加一,并在提交时验证版本号是否与数据库中的版本号匹配。如果版本号不匹配,就说明数据已经被其他事务修改,从而导致异常的抛出,报错Row was updated or deleted by another transaction。
JPA会通过数据库字段 @Version 注解更新数据库,通过乐观锁执行SQL,因此如果报错这种信息则证明存在事务冲突,比如数据库的version是2,你传递的version是1,因此更新失败。建议是直接查询数据库现在的版本是多少再去更新数据。


扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/729.html

分享给朋友:

“JPA报错Row was updated or deleted by another transaction的解决方法” 的相关文章

java编译编码问题,java编译执行时编码问题

java编译编码问题,java编译执行时编码问题

public class test {     public static void main(String[] args) {     &...

java匹配一个字符串在另外一个字符串中出现的次数,java正则start,java正则end

java匹配一个字符串在另外一个字符串中出现的次数,java正则start,java正则end

java匹配一个字符串在另外一个字符串中出现的次数,java正则start,java正则end// 正则 String pattern = "\\bgao\\b"; // 字符串 String content ...

java 可变参数

java 可变参数

java 可变参数// 定义方法 public static int sum(int... number) {     int result = 0;  &nb...

java析构函数,java finalize()

java析构函数,java finalize()

java析构函数finalize()java进行垃圾回收时会调用finalize(),用户可以用它来关闭已经打开的资源句柄等操作,具体场景比较多。和php的析构函数__destruct差不多但是这个方法在最新版本的java中提示已经废弃了,好像java9中干掉了它...

java从命令行读取字符输入

java从命令行读取字符输入

java从命令行读取字符输入java的控制台输入是由System.in提供的//11.1.每次读取1个字符// 创建bufferedReader BufferedReader br = new BufferedReader(new Inpu...

java java FileInputStream读取文件流,java FileInputStream.read方法,java FileInputStream.read[byte b]方法

java java FileInputStream读取文件流,java FileInputStream.read方法,java FileInputStream.read[byte b]方法

java FileInputStream(12.1)FileInputStream将文件读入作为流来处理,有两种实例化方式// 方式1 FileInputStream fis = new FileInputStream("./learn.t...