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

Posted

技术标签:

【中文标题】如何在带有 Oracle 数据库的 HQL 查询中使用当前日期?【英文标题】:How do I use the current date in an HQL query with an Oracle database? 【发布时间】:2010-10-05 12:38:45 【问题描述】:

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

【问题讨论】:

【参考方案1】:

不应该是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_TIMESTAMP 日期时间函数 返回数据库上当前日期、时间和时间戳的值 服务器。

【讨论】:

【参考方案2】:

current_date() 是休眠函数吗?

我会改用sysdate。像这样:

where alert.expiration > sysdate 

或者忽略一天中的时间:

where alert.expiration > trunc(sysdate) 

【讨论】:

Current_date 和 Current_timestamp 是 Oracle 函数。 Current_date = Sysdate,但 Oracle 在函数调用后不需要 ()。 CURRENT_DATE(), CURRENT_TIME(), CURRENT_TIMESTAMP() 也是 Hibernate HQL 函数。 (“Java 持久性与 Hibernate”) 只需在查询中传递 CURRENT_DATE(),例如:“and date=CURRENT_DATE()”;

以上是关于如何在带有 Oracle 数据库的 HQL 查询中使用当前日期?的主要内容,如果未能解决你的问题,请参考以下文章

如何在带有参数的spark中执行hql文件

如何使用 Hive 仓库连接器在 pyspark 中执行 HQL 文件

使用Hibernate HQL从Oracle DB检索记录时的性能问题

如何在 oracle apex 18 中编辑交互式网格(带有复杂的 sql 查询)?

带有子查询的 Oracle 更新 - 性能问题

如何在spring boot中使用hql只获取一条记录