MongoDB $ sort聚合不起作用

问题描述

我有这个聚合查询

db.getCollection('collectionName').aggregate([

{
    $facet: {
        "myAttrName": [
            {
                $match: {
                    $or: [
                        {
                            "key1": "value1"
                        },{
                            "key2": "value2"
                        }
                    ],status: "OK"
                }
            },{
                $skip: 0
            },{
                $limit: 10
            },{
                $sort: {
                    timestamp: -1
                }
            }
        ]
    }
}



])

嗯..它不能正确排序结果。我只是看到它们按照添加“ fifo”的顺序排序。

当我只是使用.sort({timestamp: -1})进行常规查找(无聚合)时,它可以正常工作。

在这里想念什么?

解决方法

聚集阶段按顺序执行,在您的查询$skip之前执行的查询$limit$sort阶段,因此排序仅适用于10个文档,

您可以在$sort阶段之前将$skip状态移动。

Playground