首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >春季数据查询dsl如何添加订单?

春季数据查询dsl如何添加订单?
EN

Stack Overflow用户
提问于 2018-10-03 13:08:35
回答 3查看 7.7K关注 0票数 5

我对Querydsl很陌生,我正在开发Spring和Querydsl来创建一个动态过滤器,我使用了接口:QueryDslPredicateExecutor,这样我就可以使用不同的实体字段过滤数据,现在我想在基于BooleanExpression.的查询中添加"order“

这是我的代码:

代码语言:javascript
复制
QPersonData _personInventory = QPersonData.personData;
BooleanBuilder query = new BooleanBuilder();

query.and(_personInventory.status.eq(status));

然后我使用查询调用了我的respository接口:

代码语言:javascript
复制
personInventoryRepository.findAll(query, pageable);

我的问题是如何根据实体上的不同字段将"order“应用于我的查询对象?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-10-03 14:35:08

最后,谢谢大家,这个解决方案对我有用:

代码语言:javascript
复制
 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()));   
票数 7
EN

Stack Overflow用户

发布于 2018-10-03 13:15:46

您可以在页面信息中添加排序:

代码语言:javascript
复制
 Sort sort = new Sort.Order(Sort.Direction.ASC,"filedname").nullsLast();
 PageRequest pageRequest = new PageRequest(pageNumber, pageSize, sort);
 personInventoryRepository.findAll(query,pageRequest); 
票数 5
EN

Stack Overflow用户

发布于 2018-10-03 13:25:25

在存储库接口中添加一个方法

代码语言:javascript
复制
findByStatus(status)

然后使用代码块,如下所示

代码语言:javascript
复制
Pageable pageable = new PageRequest(offset, limit, Direction.DESC, "updatedAt");
repository.findByStatus(status, pageable);

如果使用spring 2.0.0 =>,则使用方法

代码语言:javascript
复制
PageRequest.of(....)
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52627784

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档