34

我正在尝试使用 Hibernate 3 和 Oracle 10 编写此查询。

from Alert alert
where alert.expiration > current_date()
order by alert.priority, alert.updated, alert.name

它正在创建这样的 SQL -

Hibernate: select alert0_.ANNOUNCEMENTS_ID as ANNOUNCE1_1_, alert0_.ANNOUNCEMENT
S_NAME as ANNOUNCE2_1_, alert0_.ANNOUNCEMENTS_PRIORITY as ANNOUNCE3_1_, alert0_.
ANNOUNCEMENTS_EXPIRATION as ANNOUNCE4_1_, alert0_.ANNOUNCEMENTS_UPDATE_DATE as A
NNOUNCE5_1_ from NYC311_ANNOUNCEMENTS alert0_ where (alert0_.ANNOUNCEMENTS_EXPIR
ATION>current_date()) order by  alert0_.ANNOUNCEMENTS_PRIORITY , alert0_.ANNOUNC
EMENTS_UPDATE_DATE , alert0_.ANNOUNCEMENTS_NAME

当括号显然完全平衡时,我会遇到所有这些古怪的错误,例如“缺少右括号”。

为什么甲骨文对此感到恐惧?有没有更好的方法来编写我的 HQL 查询?

4

2 回答 2

51

不应该current_date吗?

Hibernate 会将其翻译成正确的方言。

我没有找到真正的“Hibernate 将把这个翻译成那个”的参考文档,但是这个表达式通常可以在 HQL Expressions for Hibernate 4.3中找到。

然后是Java Persistence API 2.0 (JPA)规范,它定义了 Java Persistence 查询语言 (JPQL) 的表达式及其含义,例如current_date

4.6.17.2.3 日期时间函数 functions_returning_datetime:= CURRENT_DATE | 当前时间 | CURRENT_TIMESTAMP 日期时间函数返回数据库服务器上当前日期、时间和时间戳的值。

于 2009-02-04T21:11:57.080 回答
9

current_date()休眠功能吗?

我会sysdate改用。像这样:

where alert.expiration > sysdate 

或者忽略一天中的时间:

where alert.expiration > trunc(sysdate) 
于 2009-02-04T21:10:21.170 回答