首页 > 解决方案 > MongoDB Facet 错误管道需要文本分数元数据,但没有可用的文本分数

问题描述

我创建了一个 mongodb 多面管道,以下是其子集:

    db.books.aggregate( [
    {
        $facet: {
            "categories": [
                {
                    $match: {
                        $text: { $search: "Pattern" }
                    }
                }, 
                {
                    $group: {
                        _id: "$Category",
                        count: {
                            $sum: 1
                        }
                    }
                },
                {
                    $sort: {
                        "count": -1
                    }
                },
                {
                    $project: {
                        "score": { "$meta": "textScore"},
                        "Category": "$_id",
                        "_id": 0,
                        "count": 1
                    }
                },
                {
                    $limit: 10
                }
            ]
        }
    }
])

除了类别之外,管道中还存在另外两个输出字段,但类似于上面管道中概述的结构。每当我运行此管道时,我都会收到错误消息:“管道需要文本分数元数据,但没有可用的文本分数”

此错误仅在使用构面管道时发生。单独运行每个管道阶段可以完美运行。

如果您对此有任何想法,请随时分享

谢谢!

标签: mongodb

解决方案


这已在groups.google.com/forum/#!topic/mongodb-user/Amozaj74prI中得到解答

总之,需要的是匹配阶段出现在管道的开头,而不是出现在每个方面阶段:

db.books.aggregate( [
    { $match: {$text: {$search: "Pattern"}}},
    { $addFields: {score: {$meta: "textScore"}}},
    { $facet: ... }
])

推荐阅读