我的项目使用 Hibernate 版本 4.0.1.Final 和 JPA 2.0。我需要更改一个 HQL - 添加顺序,看起来很简单,只是它现在以 SQL 语法错误结尾。
我已经定义了这个 HQL 命名查询:
SELECT s FROM Entity s WHERE s.status = :status ORDER BY s.priority, s.startDate
-> Bold 是我要添加的部分。
现在因为这个命名查询是用锁执行的 - LockModeType.PESSIMISTIC_WRITE 它为 Oracle 的更新选择创建:
select *
from (select entity.field
...more fields...
from DB_TABLE entity
where (entity.STATUS = ?)
order by entity.PRIORITY, entity.DISTRIB_START_DATE)
where rownum <= ?
for update
这个查询以
结尾java.sql.SQLSyntaxErrorException: ORA-02014 cannot select FOR UPDATE from view with DISTINCT, GROUP BY
没有订单部分它工作正常。
有什么办法可以克服这个问题吗?我只需要按顺序选择那些记录。也不能在应用程序中对它们进行排序,因为它只选择了表格的一部分。
我尝试将 Hibernate 更新到 4.2.21.Final,但结果是一样的。 Hibernate 4.3+ 需要我不使用的 JPA2.1。
也许这是 Hibernate 的错误?
最佳答案
不,这不是 Hibernate 错误,这是您必须在 Oracle 中结合 rownum
进行排序的方式。参见 this article了解更多详情。
基本上,这意味着您不能在 Oracle 中的同一查询中组合排序、rownum
和select for update
。
您必须将其分解为更多查询,具体方法取决于您的具体要求。例如:
1) 选择具有分页和排序的实体的ids:
SELECT s.id FROM Entity s WHERE s.status = :status ORDER BY s.priority, s.startDate
2) 使用获得的ids选择具有锁定的实体:
SELECT s FROM Entity s WHERE s.id in :ids AND s.status = :status
3) 如果所选实体的数量少于 id 的数量,则同时条件发生变化(状态发生变化),继续处理锁定的实例或回滚并重试整个事务。
关于java - Hibernate 为 Oracle 生成导致 ORA-02014 的查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35017754/