powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Java [игнор отключен] [закрыт для гостей] / QueryDSL вопросы
5 сообщений из 5, страница 1 из 1
QueryDSL вопросы
    #39499503
Фотография -=Koba=-
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Решил попробовать данную библиотеку и возникли вопросы

1) Like с CriteriaBuidler использовал так

Код: java
1.
2.
if (transferFilter.getLastName() != null && !transferFilter.getLastName().isEmpty())
    predicates.add(qb.like(qb.upper(root.get(TransferLog_.userInfo).get(UserInfo_.lastName)), "%" + ransferFilter.getLastName().toUpperCase() + "%"));



2) Date без времени с CriteriaBuidler использовал так

Код: java
1.
2.
3.
4.
5.
if (transferFilter.getTransactionStart() != null) {
    Expression<Date> transactionStart = qb.function("TRUNC", Date.class, root.get(TransferLog_.transaction));
    Expression<Date> fromDate = qb.function("TO_DATE", Date.class, qb.literal(DateUtils.formatRuDate(transferFilter.getTransactionStart(), "")), qb.literal("dd.mm.yyyy"));
    predicates.add(qb.greaterThanOrEqualTo(transactionStart, fromDate));
}



Собственно понравилось, что уменшился код, но как быть тут есть ли плюшки у QueryDSL по работе с Like и Date по сравнению с CriteriaBuidler
...
Рейтинг: 0 / 0
QueryDSL вопросы
    #39499560
Фотография Blazkowicz
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Не понял связи. CriteriaBuilder это ORM. QueryDSL это SQL. На фоне jOOQ, запросы QueryDSL выглядят довольно коряво.
...
Рейтинг: 0 / 0
QueryDSL вопросы
    #39499588
Фотография Blazkowicz
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Blazkowicz,

Совсем забыл что QueryDSL и в JPA умеет. Зачем это нужно. Я не знаю. Сложные запросы в Java коде лучше не писать впринципе. А на простых запросах особой разницы нет.
...
Рейтинг: 0 / 0
QueryDSL вопросы
    #39499605
Фотография -=Koba=-
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Просто решил попробовать эту библиотеку

Поубирать like такого вида "%" + ransferFilter.getLastName().toUpperCase() + "%"
И сравнение дат

Expression<Date> transactionStart = qb.function("TRUNC", Date.class, root.get(TransferLog_.transaction));
Expression<Date> fromDate = qb.function("TO_DATE", Date.class, qb.literal(DateUtils.formatRuDate(transferFilter.getTransactionStart(), "")), qb.literal("dd.mm.yyyy"));
predicates.add(qb.greaterThanOrEqualTo(transactionStart, fromDate));


Говорите JOOQ лучше будет чем QueryDSL
...
Рейтинг: 0 / 0
QueryDSL вопросы
    #39499668
Фотография Usman
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
В QueryDSL и JPA нет возможности JOIN-ить НЕсвязанные между собой таблицы
...
Рейтинг: 0 / 0
5 сообщений из 5, страница 1 из 1
Форумы / Java [игнор отключен] [закрыт для гостей] / QueryDSL вопросы
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]