如何在Oracle数据库的HQL查询中使用当前日期?
我正在尝试使用Hibernate 3和Oracle 10编写此查询。
from Alert alertwhere alert.expiration > current_date()
order by alert.priority, alert.updated, alert.name
它正在这样创建SQL-
Hibernate: select alert0_.ANNOUNCEMENTS_ID as ANNOUNCE1_1_, alert0_.ANNOUNCEMENTS_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查询?
回答:
不是current_date
吗?
Hibernate会将其翻译为适当的方言。
我没有找到真正的“ Hibernate将其翻译成该文档”参考文档,但该表达式通常可以在Hibernate
4.3的HQL表达式中找到 。
然后是Java Persistence API2.0(JPA)规范,该规范定义了JavaPersistence查询语言(JPQL)的表达式及其含义,例如current_date
:
4.6.17.2.3日期时间函数functions_returning_datetime:= CURRENT_DATE | CURRENT_TIME |
CURRENT_TIMESTAMP datetime函数返回数据库服务器上当前日期,时间和时间戳的值。
以上是 如何在Oracle数据库的HQL查询中使用当前日期? 的全部内容, 来源链接: utcz.com/qa/397601.html