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

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

高老师2年前 (2024-03-01)JAVA928
在 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一个类可以有多个构造方法,根据传参类型和个数来匹配执行哪个构造方法。public class Member {     public Member(){      ...

java增强型for循环

java增强型for循环

Java5 引入了一种主要用于数组的增强型 for 循环,类似js中的for inpublic class Member {     public static void main(String[]&...

java stringBuffer,java stringBuffer反转字符串,java stringBuffer delete删除字符/移除字符,java stringBuffer在指定位置插入字符串,java stringBuffer替换指定位置的字符串,java stringBuffer获取指定索引的值

java stringBuffer,java stringBuffer反转字符串,java stringBuffer delete删除字符/移除字符,java stringBuffer在指定位置插入字符串,java stringBuffer替换指定位置的字符串,java stringBuffer获取指定索引的值

java stringBuffer(1).stringBuffer和stringBuilder区别stringBuffer是线程安全的,stringBuilder速度更快(2).简单的stringBuffer例子StringBuffer sBuffer = new&nb...

java获取时间戳,java时间戳获取

java获取时间戳,java时间戳获取

System.out.println("当前时间戳(秒): " + System.currentTimeMillis()/1000); System.out.println("当前时间戳(毫秒): " +&nb...

java lookingAt匹配字符串和java matches匹配字符串,java正则replaceAll,java正则replaceFirst

java lookingAt匹配字符串和java matches匹配字符串,java正则replaceAll,java正则replaceFirst

(4).java lookingAt匹配字符串和java matches匹配字符串lookingAt不要求整个字符串全匹配,例如me和me_you都是匹配的,但是lookingAt从第一个字符串开始匹配,匹配失败了也不会继续匹配,意味着me和you_me是无法匹配的matches匹配字符串要求全部匹...

java方法重载

java方法重载

(7).java方法重载一个类的两个方法拥有相同的名字,但是有不同的参数列表,叫做方法重载,例如public static int sum(int a, int b) {     retur...