Hibernate:在 Hibernate 5.4.x 版本中运行此 SQL 查询“alter session enable parallel dml”时出错

问题描述

我已在我的应用程序中将 Hibernate 4.x 版本升级到 Hibernate 5.4.x 版本。

sql 查询下运行时出现以下错误

javax.persistence.TransactionrequiredException:执行一个 更新/删除查询在 org.hibernate.internal.AbstractSharedSessionContract.checkTransactionNeededForUpdateOperation(AbstractSharedSessionContract.java:413) 在 org.hibernate.query.internal.AbstractProducedQuery.executeUpdate(AbstractProducedQuery.java:1668)

sql 查询

hibernateSession.createsqlQuery("alter session enable parallel dml").executeUpdate();

在上述 dml 查询失败后,并行运行的删除查询也失败。

我曾尝试在方法级别和类级别使用 @Transactional 注释(导入 org.springframework.transaction.annotation.Transactional;),但这并没有解决我的问题。

任何解决错误的建议都值得高度赞赏。

解决方法

看起来您的事务管理器集成无法正常工作,因为 Hibernate 无法加入事务。不确定您的 Spring 配置如何,但肯定存在问题。我猜你也更新了 Spring?也许您使用的是现在不受支持的配置?

,

我在代码中添加了开始事务以解决上述错误。

Transaction trans = session.beginTransaction();

这个解决方案对我来说解决了这个错误。

javax.persistence.TransactionRequiredException:执行一个 更新/删除查询

但现在低于新错误

错误 | ORA-12801: 并行查询服务器 P00V 中发出错误信号 ORA-12829: 死锁 - itls 在块 3591658 被兄弟姐妹占用 文件 175

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...