[英]Spring data query dsl how to add order by?
我是 Querydsl 的新手,我正在使用 Spring 數據和 Querydsl 來制作動態過濾器,我使用接口: QueryDslPredicateExecutor所以我可以使用不同的實體字段過濾數據,現在我想在我的查詢中添加“order by”基於BooleanExpression 。
這是我的代碼:
QPersonData _personInventory = QPersonData.personData;
BooleanBuilder query = new BooleanBuilder();
query.and(_personInventory.status.eq(status));
然后我使用查詢調用了我的存儲庫接口:
personInventoryRepository.findAll(query, pageable);
我的問題是如何根據實體上的不同字段將“order by”應用於查詢對象?
最后感謝大家這個解決方案對我有用:
QPersonData _personInventory = QPersonData.personData;
BooleanBuilder query = new BooleanBuilder();
query.and(_personInventory .status.eq(status));
personInventoryRepository.findAll(query,0, Integer.MAX_VALUE,new QSort(_personInventory.field1.asc(),_personInventory.field2.asc()));
您可以為頁面信息添加排序:
Sort sort = new Sort.Order(Sort.Direction.ASC,"filedname").nullsLast();
PageRequest pageRequest = new PageRequest(pageNumber, pageSize, sort);
personInventoryRepository.findAll(query,pageRequest);
在您的存儲庫界面中添加一個方法
findByStatus(status)
然后使用如下代碼塊
Pageable pageable = new PageRequest(offset, limit, Direction.DESC, "updatedAt");
repository.findByStatus(status, pageable);
如果您使用 spring boot 2.0.0 => 然后使用方法
PageRequest.of(....)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.