如何在HQL查询中使用Oracle数据库中的当前日期?

时间:2009-02-04 20:58:37

标签: oracle hibernate hql

我正在尝试使用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查询?

2 个答案:

答案 0 :(得分:46)

不应该是current_date吗?

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

我没有找到真正的“Hibernate将其转换为”参考文档,但通常可以在HQL Expressions for Hibernate 4.3中找到表达式。

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

  

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

答案 1 :(得分:7)

current_date()是Hibernate函数吗?

我会改用sysdate。像这样:

where alert.expiration > sysdate 

或忽略时间:

where alert.expiration > trunc(sysdate)