NamedQuery с CONCAT возвращает ошибку

Я пытаюсь выполнить следующий запрос выбора:

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 уже отсортирован на основе значений в объединенном столбце.

Спасибо


person Metal Wing    schedule 23.08.2012    source источник
comment
Является ли псевдоним datetime проблемой? (datetime обычно является ключевым словом SQL.)   -  person EthanB    schedule 23.08.2012
comment
@EthanB Нет, потому что первый (исходный sql) запрос работает. На всякий случай попробовал заменить на «банан» - та же ошибка. знак равно   -  person Metal Wing    schedule 23.08.2012
comment
Похоже на ошибку в парсере SQL провайдера JPA.   -  person Jim Garrison    schedule 24.08.2012


Ответы (1)


Существует разница в JPA 1.0 и JPA 2.0. JPA 2.0 включает "[AS] result_variable" в элементы выбора, который отсутствует в 1.0. Так что вы можете попробовать вот так;

  SELECT c, CONCAT(c.userDate, ' - ', c.userTime) FROM Todonote c WHERE c.todoTask = :taskNumber ORDER BY CONCAT(c.userDate, ' - ', c.userTime) DESC
person Sai Ye Yan Naing Aye    schedule 24.08.2012