使用 $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
      }
    }
  ]
})

Working example