MongoDB的skip,limit,sort执行顺序---先sort,后skip再limit, 跟写的顺序无关

所有数据都是不一样的。

先看 skip和limit, 当两者一起使用的时候, 不管其位置顺序,默认先skip,再limit。

如下图:


再看sort ,【6】语句,我的数据已经排序。之后三条数据无论怎么变换都是一样的排序结果。(这里未列出所有可能。将skip和limit位置变化后跟sort组合,但是结果仍然相同)

由结果可以得出,当sort,skip,limit一起使用时,无论其位置变化,总是先sort再skip,最后limit。


但是我想要先跳过,再限制条数 最后才排序怎么办?

可以用aggregate, aggregate有管道流的性质,$skip,$limit,$sort执行顺序跟位置一致。



位置决定执行顺序。




聚合管道的优化:

http://docs.mongoing.com/manual-zh/core/aggregation-pipeline-optimization.html#agg-sort-skip-limit-sequence


0
0
 
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值