1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/selfly-sonsure-dumper

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
В этом репозитории не указан файл с открытой лицензией (LICENSE). При использовании обратитесь к конкретному описанию проекта и его зависимостям в коде.
Клонировать/Скачать
append-sql.md 1.4 КБ
Копировать Редактировать Web IDE Исходные данные Просмотреть построчно История
gitlife-traslator Отправлено 28.11.2024 13:43 e04b5c0

Соединение фрагментов SQL

В некоторых случаях при использовании имён классов или атрибутов удобно составлять часть SQL-запросов. Однако часть запросов требует использования функций, и таким способом их составить не получится.

Тогда можно использовать соединение фрагментов SQL для реализации задачи.

Пример 1, традиционный способ

UserInfo userInfo = daoTemplate.selectFrom(UserInfo.class)
        .where("userAge", ">", 5)
        .append("and userInfoId = (select max(t2.userInfoId) from UserInfo t2 where t2.userInfoId < ?)", 40)
        .singleResult(UserInfo.class);
Assert.assertNotNull(userInfo);

Пример 2, также поддерживается именованный способ

Map<String, Object> params = new HashMap<>();
params.put("userInfoId", 40L);
UserInfo userInfo = daoTemplate.selectFrom(UserInfo.class)
        .namedParameter()
        .where("userAge", ">", 5)
        .append("and userInfoId = (select max(t2.userInfoId) from UserInfo t2 where t2.userInfoId < :userInfoId)", params)
        .singleResult(UserInfo.class);
Assert.assertNotNull(userInfo);

Опубликовать ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://api.gitlife.ru/oschina-mirror/selfly-sonsure-dumper.git
git@api.gitlife.ru:oschina-mirror/selfly-sonsure-dumper.git
oschina-mirror
selfly-sonsure-dumper
selfly-sonsure-dumper
master