Я получаю результаты из БД, используя критерии и предикаты, и я получил свой список результатов, и я пытаюсь применить нумерацию страниц и сортировку, но это не работает.Пожалуйста, помогите мне, где мне не хватает, Вот мой код:
private Page<Books> getFiltereBooks(Params params,
PageRequest sortOrder) {
CriteriaBuilder builder = em.getCriteriaBuilder();
CriteriaQuery<Books> criteria = builder.createQuery(Books.class);
Root<Books> booksRoot = criteria.from(Books.class);
List<Predicate> predicates = new ArrayList<Predicate>();
predicates.add(builder.equal(booksRoot.get("id"), params.getRequestId()));
predicates.add(builder.like(builder.lower(booksRoot.get("name")),
"%" + params.getName().toLowerCase() + "%"));
criteria.where(builder.and(predicates.toArray( new Predicate[predicates.size()])));
criteria.orderBy(builder.desc(booksRoot.get("id")));
List<Books> result = em.createQuery(criteria).getResultList();
int total = result.size();
Page<Books> result1 = new PageImpl<>(result, sortOrder, total);
return result1;
}
, когда я использую этот код:
Page<Books> result1 = new PageImpl<>(result, sortOrder, total);
это не работает, я хочу вернуть объект страницы.любая помощь приветствуется.