我对Querydsl很陌生,我正在开发Spring和Querydsl来创建一个动态过滤器,我使用了接口:QueryDslPredicateExecutor,这样我就可以使用不同的实体字段过滤数据,现在我想在基于BooleanExpression.的查询中添加"order“
这是我的代码:
QPersonData _personInventory = QPersonData.personData;
BooleanBuilder query = new BooleanBuilder();
query.and(_personInventory.status.eq(status));
然后我使用查询调用了我的respository接口:
personInventoryRepository.findAll(query, pageable);
我的问题是如何根据实体上的不同字段将"order“应用于我的查询对象?
发布于 2018-10-03 06:35:08
最后,谢谢大家,这个解决方案对我有用:
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()));
发布于 2018-10-03 05:15:46
您可以在页面信息中添加排序:
Sort sort = new Sort.Order(Sort.Direction.ASC,"filedname").nullsLast();
PageRequest pageRequest = new PageRequest(pageNumber, pageSize, sort);
personInventoryRepository.findAll(query,pageRequest);
发布于 2018-10-03 05:25:25
在存储库接口中添加一个方法
findByStatus(status)
然后使用代码块,如下所示
Pageable pageable = new PageRequest(offset, limit, Direction.DESC, "updatedAt");
repository.findByStatus(status, pageable);
如果使用spring 2.0.0 =>,则使用方法
PageRequest.of(....)
https://stackoverflow.com/questions/52627784
复制