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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值