首页 > 解决方案 > 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})它可以正常工作。

我在这里缺少什么?

标签: mongodbnosqlaggregation

解决方案


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

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

操场


推荐阅读