В некоторых случаях при использовании имён классов или атрибутов удобно составлять часть SQL-запросов. Однако часть запросов требует использования функций, и таким способом их составить не получится.
Тогда можно использовать соединение фрагментов SQL для реализации задачи.
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);
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 )