使用 $gte 和 $lt 来选择特定字段值的不同范围
using $gte and $lt for picking different rages of a specific field value
我尝试选择成本字段在 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 },
],
},
},
},
]);
通过上述方法,我从 mongoose 收到了这个错误。
"message": "unknown operator: $or",
关于使用 mongoose
在 MongoDB
中选择范围的任何想法
你应该使用 find
查询。
db.collection.find({
"fieldA": {
"$in": arryOfIds,
},
"$or": [
{
"cost": {
"$gte": 0,
"$lt": 5
}
},
{
"cost": {
"$gte": 10,
"$lt": 15
}
}
]
})
我尝试选择成本字段在 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 },
],
},
},
},
]);
通过上述方法,我从 mongoose 收到了这个错误。
"message": "unknown operator: $or",
关于使用 mongoose
MongoDB
中选择范围的任何想法
你应该使用 find
查询。
db.collection.find({
"fieldA": {
"$in": arryOfIds,
},
"$or": [
{
"cost": {
"$gte": 0,
"$lt": 5
}
},
{
"cost": {
"$gte": 10,
"$lt": 15
}
}
]
})