MongoDB让人挠破头的分页问题

空想家 发布于 2013/08/02 14:07
阅读 3K+
收藏 1

我们已经知道MongoDB的skip分页方式是效率低下的,很多社区里都有前人做过测试。问题是:如果不用skip,到底如何做分页?

很多人,包括《MongoDB权威指南》中给出的解决方案是:获取上一页的最后一条数据,然后使用gt和limit获取下一页的数据,关于这一点我已经实现,但问题又出现了:怎样获取上一页的数据?于是我依葫芦画瓢,获取了上一页的第一条数据和上上一页的最后一条数据,总算是用lt和gt搞定了。

可是,太丑陋了!这还不算完!

当前页是第1页,如果用户不是点击下一页,而是直接点击第10页,我如何能够知道第9页的最后一条数据是什么?

实在难以想象MongoDB会在如此常用的功能上具有这么大的缺陷,肯能是我研究得还不够深入,大家有没有其他的实现方案呢?

加载中
0
周明岐
周明岐

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

0
黄杰忠
按照你说的那样,用gt跟limit实现分页,若排的顺序是一直变的呢,比如论坛发帖,第一页肯定是最新发布的,那么前一秒的第一页,搞不好现在变成第二页。所以我觉得这样的实现有局限性。。。
空想家
空想家
你说的问题确实也存在,但现在的情况是最基本的分页功能都无法实现,真是纠结!
0
d
dbtop
看看sina微博是如何做的吧
0
空想家
空想家
求大神指点啊
0
fengjian
fengjian
这个东西用着挺蛋疼
0
hello123
hello123
用gt分页,那如果排序字段有相同的,那还能实现分页吗。
0
CC_Canon
CC_Canon
绑定,确实很烦的说。权威指南上也写得不详细。
0
大丈夫没问题
大丈夫没问题
查索引找出ID,根据ID再在mongo里查?
返回顶部
顶部