MongoDB将查找与文本搜索相结合



我正在尝试使用.find()查询过滤MongoDB集合并对结果运行文本搜索以降低查询成本,但我似乎无法链接命令。

这是我尝试过的(不起作用):

db.jobs.find({
    "salary.max": {
        $gte: 50000,
        $lte: 120000
    }
}).runCommand("text", {
    search: "metal"
})

我还以相反的顺序尝试了查询,这违背了目的并且也不起作用。

有没有办法将.runCommand()链接到MongoDB中的.find()

.find函数返回一个没有.runCommand函数的DBCursor。所以这显然是行不通的。

但是,有效的方法是在text数据库命令中使用查找查询。正如您在文本搜索文档中所读到的那样,您可以将filter作为可选参数传递给文本命令。这些过滤器文档的工作方式与您传递给 find 的完全相同。

db.jobs.runCommand( "text", { 
    search: "metal",
    filter: { 
        "salary.max": {
            $gte: 50000,
            $lte: 120000
        }
    }
} );

最新更新