QueryDSL Порядок по вычисляемому полюJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 QueryDSL Порядок по вычисляемому полю

Сообщение Anonymous »

В нашем приложении мы используем querydsl для извлечения объектов и преобразования их в объект представления.
Этот объект представления имеет поле, называемое активным. Это определяется тем, наступает ли определенная дата объекта до сегодняшнего дня (активный = ложь) или после сегодняшнего дня (активный = истина). Все идет хорошо, делая это. Проблема в том, что при попытке упорядочить это выражение (

Код: Выделить всё

QEntity.someDate > today). В результате спящий режим выдает эту ошибку: 

org.hibernate.hql.internal.ast.QuerySyntaxException: unexpected AST node: > near line 3, column 40 [select object.someField as someAlias, (object.someDate > ?1) as active, object as objectAlias
from com.example.Object object
order by object.someDate > ?1 asc]
Я создаю OrderSpecifier следующим образом:

Код: Выделить всё

    @Override
public OrderSpecifier getOrderByClause(SortKey sortKey) {
BooleanExpression expression = getBooleanPath(); // This is the expression: (object.someDate > ?1)
if (sortKey.getSortOrder() == ESortOrder.ASCENDING) {
return new OrderSpecifier(Order.ASC, expression);
}
return new OrderSpecifier(Order.DESC, expression);
}
Я тоже пробовал так:

Код: Выделить всё

    @Override
public OrderSpecifier getOrderByClause(SortKey sortKey) {
BooleanExpression expression = getBooleanPath();
if (sortKey.getSortOrder() == ESortOrder.ASCENDING) {
return new CaseBuilder().when(expression.isFalse()).then(1).otherwise(2).asc();
}
return new CaseBuilder().when(expression.isTrue()).then(1).otherwise(2).desc();
}
Что приводит к аналогичной ошибке:

Код: Выделить всё

org.hibernate.hql.internal.ast.QuerySyntaxException: unexpected AST node: > near line 3, column 40 [select object.someField as someAlias, (object.someDate > ?1) as active, object as objectAlias
from com.example.Object object
order by case when (object.someDate > ?1 = ?2) then ?3 else 2 end asc]
И, наконец, вот так:

Код: Выделить всё

    @Override
public OrderSpecifier getOrderByClause(SortKey sortKey) {
BooleanExpression expression = getBooleanPath();
if (sortKey.getSortOrder() == ESortOrder.ASCENDING) {
return new CaseBuilder().when(expression.eq(true)).then(1).otherwise(2).asc();
}
return new CaseBuilder().when(expression.eq(true)).then(1).otherwise(2).desc();
}
Выдает ту же ошибку, что и предыдущая.


Подробнее здесь: https://stackoverflow.com/questions/591 ... ated-field
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»