Pagination with mongoTemplate(使用 mongoTemplate 进行分页)
问题描述
我有一个带有 Pageable 的查询:
I have a Query with Pageable:
Query query = new Query().with(new PageRequests(page, size))
如何使用 MongoTemplate 执行它?我没有看到一个方法返回 Page<T>.
How can I execute it with MongoTemplate ? I don't see a single method returning Page<T>.
推荐答案
确实MongoTemplate没有findXXX with Pageables.
It's true that the MongoTemplate doesn't have findXXX with Pageables.
但是你可以使用 Spring Repository PageableExecutionUtils 来实现.
But you can use the Spring Repository PageableExecutionUtils for that.
在您的示例中,它看起来像这样:
In your example it would look like this:
Pageable pageable = new PageRequests(page, size);
Query query = new Query().with(pageable);
List<XXX> list = mongoTemplate.find(query, XXX.class);
return PageableExecutionUtils.getPage(
list,
pageable,
() -> mongoTemplate.count(Query.of(query).limit(-1).skip(-1), XXX.class));
就像在原始的 Spring Data Repository 中一样,PageableExecutionUtils 将执行一个计数请求并将其包装到一个漂亮的 Page 中.
Like in the original Spring Data Repository, the PageableExecutionUtils will do a count request and wrap it into a nice Page for you.
这里你可以看到spring也在做同样的事情.
Here you can see that spring is doing the same.
这篇关于使用 mongoTemplate 进行分页的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:使用 mongoTemplate 进行分页
基础教程推荐
- Struts2 URL 无法访问 2022-01-01
- 无法复制:“比较方法违反了它的一般约定!" 2022-01-01
- Spring AOP错误无法懒惰地为此建议构建thisJoinPoin 2022-09-13
- 如何对 Java Hashmap 中的值求和 2022-01-01
- 使用堆栈算法进行括号/括号匹配 2022-01-01
- 存储 20 位数字的数据类型 2022-01-01
- REST Web 服务返回 415 - 不支持的媒体类型 2022-01-01
- RabbitMQ:消息保持“未确认"; 2022-01-01
- 修改 void 函数的输入参数,然后读取 2022-01-01
- 问题http://apache.org/xml/features/xinclude测试日志4j 2 2022-01-01
