E2r*_*abi 5 java spring querydsl spring-data spring-data-jpa
我是 Querydsl 的新手,我正在使用 Spring 数据和 Querydsl 来制作动态过滤器,我使用接口:QueryDslPredicateExecutor所以我可以使用不同的实体字段过滤数据,现在我想在我的查询中添加“order by”基于BooleanExpression。
这是我的代码:
QPersonData _personInventory = QPersonData.personData;
BooleanBuilder query = new BooleanBuilder();
query.and(_personInventory.status.eq(status));
Run Code Online (Sandbox Code Playgroud)
然后我使用查询调用了我的存储库接口:
personInventoryRepository.findAll(query, pageable);
Run Code Online (Sandbox Code Playgroud)
我的问题是如何根据实体上的不同字段将“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()));
Run Code Online (Sandbox Code Playgroud)
您可以为页面信息添加排序:
Sort sort = new Sort.Order(Sort.Direction.ASC,"filedname").nullsLast();
PageRequest pageRequest = new PageRequest(pageNumber, pageSize, sort);
personInventoryRepository.findAll(query,pageRequest);
Run Code Online (Sandbox Code Playgroud)
小智 5
在存储库界面中添加一个方法
findByStatus(status)
Run Code Online (Sandbox Code Playgroud)
然后使用如下代码块
Pageable pageable = new PageRequest(offset, limit, Direction.DESC, "updatedAt");
repository.findByStatus(status, pageable);
Run Code Online (Sandbox Code Playgroud)
如果您使用 spring boot 2.0.0 => 那么使用方法
PageRequest.of(....)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4986 次 |
| 最近记录: |