开发者社区> 问答> 正文

有关MongoDB的分页问题

我们已经知道MongoDB的skip分页方式是效率低下的,很多社区里都有前人做过测试。问题是:如果不用skip,到底如何做分页?
很多人,包括《MongoDB权威指南》中给出的解决方案是:获取上一页的最后一条数据,然后使用gt和limit获取下一页的数据,关于这一点我已经实现,但问题又出现了:怎样获取上一页的数据?于是我依葫芦画瓢,获取了上一页的第一条数据和上上一页的最后一条数据,总算是用lt和gt搞定了。
可是当前页是第1页,如果用户不是点击下一页,而是直接点击第10页,我如何能够知道第9页的最后一条数据是什么?
实在难以想象MongoDB会在如此常用的功能上具有这么大的缺陷,肯能是我研究得还不够深入,大家有没有其他的实现方案呢?

展开
收起
落地花开啦 2016-02-21 15:35:48 2608 0
1 条回答
写回答
取消 提交回答
  • 喜欢技术,喜欢努力的人

    如果你对连续查询的结果一致性要求比较高,就可以先把查询出来的id缓存起来,然后根据id再查询出内容,一次一页的数据并不多,你用$in的情况下,效率也不错

    2019-07-17 18:46:00
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Data as a Service - 数据即服务 -- MongoDB⾼级应⽤模式 立即下载
MongoDB多数据中心的方案选型之路 立即下载
饿了么高级架构师陈东明:MongoDB是如何逐步提高可靠性的 立即下载