【问题标题】:NamedQuery with a CONCAT returns error带有 CONCAT 的 NamedQuery 返回错误
【发布时间】:2012-08-23 16:24:26
【问题描述】:

我正在尝试执行如下选择查询:

SELECT *, CONCAT(TNUSERDATE, ' - ', TNUSERTIME) AS datetime 
  FROM TODONOTE WHERE TNTDKEY='TD00019148' ORDER BY datetime DESC;

该查询有效;但是,当我尝试将其转移到命名查询中时:

@NamedQueries({
    @NamedQuery(name = "Todonote.findAll", query = "SELECT c FROM Todonote c"),
    @NamedQuery(name = "Todonote.findByTaskNumber", query = "SELECT c, CONCAT(c.userDate, ' - ', c.userTime) AS datetime FROM Todonote c WHERE c.todoTask = :taskNumber ORDER BY datetime DESC")
})

我收到一个错误

[EL Severe]: 2012-08-23 12:15:39.111--ServerSession(841933)--Local Exception Stack: 
Exception [EclipseLink-6168] (Eclipse Persistence Services - 2.3.0.v20110604-r9504): org.eclipse.persistence.exceptions.QueryException
Exception Description: Query failed to prepare, unexpected error occurred: [java.lang.ClassCastException: org.eclipse.persistence.internal.jpa.parsing.ConcatNode cannot be cast to org.eclipse.persistence.internal.jpa.parsing.AliasableNode].
Internal Exception: java.lang.ClassCastException: org.eclipse.persistence.internal.jpa.parsing.ConcatNode cannot be cast to org.eclipse.persistence.internal.jpa.parsing.AliasableNode
Query: JPAQuery(name="Todonote.findByTaskNumber" )

我不确定问题是什么或我将如何执行 concat 语句。我的目标是运行 namedQuery,返回给我的 ResultList 已经根据连接列中的值进行了排序。

谢谢

【问题讨论】:

  • 是别名datetime 的问题吗? (datetime 通常是一个 SQL 关键字。)
  • @EthanB 不,因为第一个(原始 sql)查询有效。以防万一我尝试用“香蕉”替换它 - 同样的错误。 =(
  • 看起来像是 JPA 提供程序的 SQL 解析器中的错误。

标签: java jpa eclipselink concatenation named-query


【解决方案1】:

JPA 1.0 和 JPA 2.0 有所不同。在 JPA 2.0 中,选择项中包含 1.0 中缺少的“[AS] result_variable”。所以你可以这样尝试;

  SELECT c, CONCAT(c.userDate, ' - ', c.userTime) FROM Todonote c WHERE c.todoTask = :taskNumber ORDER BY CONCAT(c.userDate, ' - ', c.userTime) DESC

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-07-14
    • 1970-01-01
    • 1970-01-01
    • 2018-12-26
    • 1970-01-01
    • 1970-01-01
    • 2022-10-14
    • 1970-01-01
    相关资源
    最近更新 更多