- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到一个问题,因为实体的某个删除是在 2 个线程中执行的,所以出现了 StaleStateException
。这是因为由 REST 调用启动的线程正在删除对象并调用另一个服务来清理其中的一些内容,但该另一个服务最终将一些数据放在 Kafka 流上。这个 Kafka 流不断地从另一个线程读取,也会导致对象被删除。但取决于谁先到达那里我可以得到这个异常(exception):
由以下原因引起:org.hibernate.StaleStateException:批量更新从更新 [0] 返回意外的行计数;实际行数:0;预期:1;执行的语句:HikariProxyPreparedStatement@821401258 包装从 notification_setting 中删除,其中 id='f47ef4b1-eb54-4d3a-a6f0-fc4518704288'::uuid 和 db_version=0
现在,在这种特殊情况下,删除是由系统操作完成的,我真的不关心 StateStateException
和产生的 OptimisticLockingException
。这两个操作都只需删除该对象,我不介意谁先到达它。但我不想从该实体中完全删除 @Version 属性。我可以暂时禁用特定删除的乐观锁定吗?
代码不太相关,但就在这里。我已经尝试过按 id 删除,但 deleteAll
也有同样的问题。
eventLevelSubscriptions.forEach(
eventLevelSubscription -> notificationEventLevelSubscriptionRepo.deleteById(eventLevelSubscription.getId()));
notificationSettings.forEach(notificationSetting -> notificationSettingRepo.deleteById(notificationSetting.getId()));
em.flush();
for (NotificationSettingKey notificationSettingKey : notificationSettingKeys) {
kafkaWritingService.removeNotificationSetting(producer, notificationSettingKey);
}
注意刷新,因为我们需要确保这部分在更新 Kafka 上的另一个流之前成功。
我尝试简单地尝试/捕获整个代码,因为我什至不需要在第二个线程中执行删除,因为它们已经在第一个线程中完成,但是 Hibernate 似乎进入了损坏状态,其中最后还是抛出异常。
Exception in thread "Thread-6" org.springframework.transaction.UnexpectedRollbackException: Transaction silently rolled back because it has been marked as rollback-only
at org.springframework.transaction.support.AbstractPlatformTransactionManager.processCommit(AbstractPlatformTransactionManager.java:753)
at org.springframework.transaction.interceptor.TransactionAspectSupport.commitTransactionAfterReturning(TransactionAspectSupport.java:631)
at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:385)
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:99)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:747)
at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:689)
...
at java.base/java.lang.Thread.run(Unknown Source) (note: this is my kafka consumer thread)
最佳答案
A) 您无法禁用乐观锁定。你为什么要使用它?此异常可能表明您的逻辑不一致。检查一下你的逻辑是否真的正确。
B) 如果在检查后您仍然想保持逻辑不变,则意味着您应该在这种情况下将此异常视为正确行为(否则返回 A 并检查/更改逻辑),这意味着您应该捕获异常。
C) 如果您当前的代码在单个事务中运行:请勿在单个步骤中删除所有实体,因为其中一些实体可能已被删除,而其他实体则尚未删除。解决方案如下:
deleteById()
的调用放入新方法forEach()
中调用此方法而不是调用存储库D) 还考虑一种非面向对象的方法:使用 JPQL 或 SQL 删除条目。优点:如果之前已经删除了一些条目,也不会有异常(exception)。
关于java - 即使实体具有 @Version 属性,我也可以在 Hibernate 中暂时禁用乐观锁定吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59467843/
我正在使用JQuery Mobile,有两个可用版本:稳定版和旧版。我不熟悉后者。 什么是旧版?或与稳定版有什么区别? 建议在生产现场中使用哪一个? 非常感谢 最佳答案 旧版本是一个旧的稳定版本,由于
Lotus Notes 具有“版本控制”功能。您可以将其设置为在用户需要单击 File->New->Version 以创建新版本的模式下工作。我想在表单上的按钮中使用该功能。 有没有办法(使用 Lot
关闭。这个问题是opinion-based 。目前不接受答案。 已关闭10 年前。 已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 是否有任何
我对使用数据库和数据库设计/创建模式非常陌生,我非常感谢一些建议/建议。我正在创建一个应用程序,用户在其中输入数据,并向用户提供该数据的版本控制。用户可以进入并恢复更改或更新值(有点像 git)等,我
尝试启动带头 Selenium session 时出现此错误。 我使用的命令是driver = webdriver.Chrome(executable_path=r'C:\Users\Administ
Apple 的文档本来可以更清楚地说明如何提交更新版本。 正如标题所问,有什么区别 itunes connect 中的版本号(提交更新时必须提供) xcode 中的捆绑版本 捆绑版本字符串,短 它们有
当我在我的 Android 设备上运行我的应用程序时出现错误: meteor run android-device --settings settings.json --mobile-server=m
v = data.getValues(XP_PHONE); for (int i = 0; i alter 'table_foo', {NAME => 'column_fam_foo', V
我在Google CoLab中有这样一个错误:。以下是我的Cuda和Torch版本:。CUDA版本:。这是pytorch版本:2.0.1+cu118我试图安装Cuda 11.8,但没有成功。
我从其他用户那里发现了“类似”的问题,但没有一个答案有效。我正在尝试安装这些软件包: if (!require("BiocManager")) install.packages("BiocMana
我正在使用 Version Maven Plugin插件 use-latest-versions将 groupID=com.example* 内部依赖版本更新到最新版本的功能。这是使用 Jenkins
我是 Kotlin 应用程序开发的初学者。当我尝试构建应用程序时发生以下错误 - e: C:/Users/Lenovo/.gradle/caches/transforms-2/files-2.1/32
我正在尝试安装一个名为 metaBIT 的程序。我能够将它添加到我的路径中。但是当我执行时: metaBIT -h 它出错并给我这个: Traceback (most recent call last
在使用选项 -smt2 -in 启动 Z3 后,我可以获取 Z3 的版本吗?有点像 (get-z3-version) ; Z3 4.3.2 x64 // Desired reply 最佳答案 在SM
这个问题在这里已经有了答案: What is the difference between Version and 'Runtime Version' in .Net? (1 个回答) 关闭 9 年
new Version(AssemblyFileVersionAttribute.Version) 总是会成功吗? 这是我的代码。 Contract.Ensures(Contract.Result()
我正在尝试针对另一个使用 libcurl 共享库的共享库 (libtheirstuff.so) 交叉编译我自己的共享库 (libmystuff.so),但出现以下错误: libmystuff.so:
在 Bazaar 中,如果您在 foo.html 中有冲突,它将生成额外的 3 个文件 foo.html.BASE foo.html.OTHER foo.html.THIS 那么你可以 diff -N
我的 java 7 和 java 8 都安装在我的 Windows 系统的 C:\Program Files\Java 下 在环境的路径中我像这样指定了java 7的路径。 %JAVA_HOME%/b
#version 330 和 #version 330 core 有什么区别? 核心重要吗? 最佳答案 这两个版本声明是等价的。 核心 是默认值。来自 GLSL 3.30 规范: If no prof
我是一名优秀的程序员,十分优秀!