Проблемы с подсчетом запросов JDOQL - PullRequest
1 голос
/ 22 октября 2010

У меня проблемы с подсчетами подзапросов в JDOQL (с использованием DataNucleus).Следующий запрос

SELECT this.price
FROM com.mysema.query.jdo.test.domain.Product
WHERE (SELECT count(other)
FROM com.mysema.query.jdo.test.domain.Product other
WHERE other.price > this.price) > a1
PARAMETERS java.lang.Long a1

вызывает исключение

javax.jdo.JDOUserException: Cannot perform operation ">" on SubqueryExpression "(SELECT COUNT("OTHER".PRODUCT_ID) FROM PRODUCT "OTHER" WHERE "OTHER".PRICE > THIS.PRICE)" and IntegerLiteral "?"
    at org.datanucleus.jdo.NucleusJDOHelper.getJDOExceptionForNucleusException(NucleusJDOHelper.java:390)
    at org.datanucleus.jdo.JDOQuery.executeWithArray(JDOQuery.java:321)

Следующий запрос также не работает:

SELECT this.price
FROM com.mysema.query.jdo.test.domain.Product
WHERE !(SELECT other
FROM com.mysema.query.jdo.test.domain.Product other
WHERE other.price > this.price).isEmpty()

Как правильно убедиться, что подзапросрезультат не пустой?

1 Ответ

1 голос
/ 22 октября 2010

Я получил исправленные проблемы при обновлении с DataNucleus 2.0.4 до 2.1.2. Первый запрос работает.

...