gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 05:00:02 28 4
gpt4 key购买 nike

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

最佳答案

不应该是current_date吗?

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

我没有找到真正的“Hibernate 会将这个翻译成那个”的引用文档,但是这个表达式一般可以在 HQL Expressions for Hibernate 4.3 中找到。 .

然后是Java Persistence API 2.0 (JPA)规范定义了 Java 持久性查询语言 (JPQL) 的表达式及其含义,例如对于当前日期:

4.6.17.2.3 Datetime Functions functions_returning_datetime:= CURRENT_DATE | CURRENT_TIME | CURRENT_TIMESTAMP The datetime functions return the value of current date, time, and timestamp on the database server.

关于oracle - 如何在 Oracle 数据库的 HQL 查询中使用当前日期?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/513317/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com