我正在尝试使用.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
}
}
} );