我尝试挑选成本字段在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",
关于使用mongoose
在MongoDB
中选取范围的任何想法
您应该使用find
查询来完成此操作。
db.collection.find({
"fieldA": {
"$in": arryOfIds,
},
"$or": [
{
"cost": {
"$gte": 0,
"$lt": 5
}
},
{
"cost": {
"$gte": 10,
"$lt": 15
}
}
]
})
工作示例