使用$gte和$lt来选择特定字段值的不同范围



我尝试挑选成本字段在0到5之间的文档,然后尝试挑选成本范围在10到15之间的文档。为此,我使用MongoDB aggregation

const something = await dummyModel.aggregate([
{
$match: {
fieldA: {
$in: arryOfIds,
},
cost: {
$or: [
{ $gte: 0, $lt: 5 },
{ $gte: 10, $lt: 15 },
],
},
},
},
]);

通过上面的方法,我从猫鼬那里得到了这个错误。

"message": "unknown operator: $or",

关于使用mongooseMongoDB中选取范围的任何想法

您应该使用find查询来完成此操作。

db.collection.find({
"fieldA": {
"$in": arryOfIds,
},
"$or": [
{
"cost": {
"$gte": 0,
"$lt": 5
}
},
{
"cost": {
"$gte": 10,
"$lt": 15
}
}
]
})

工作示例

最新更新