如果值大于零减 1,则更新数组的所有元素 MongoDB

发布于 2025-01-13 01:24:01 字数 540 浏览 0 评论 0原文

我在 MongoDB 中非常初学者,我有一个集合称为 users

user 1:

{
  "_id": 1,
  "city_name": "Newyork",
  "device":[
    {
      "ime_number" : 1234343,
      "validity" : 40
    }
    ]
}

user 2:

{
  "_id": 2,
  "city_name": "London",
  "device":[
    {
      "ime_number" : 3434334,
      "validity" : 30
    }
    ]
}

我想更新集合中的所有有效性大于零有效性减量 1

我尝试了这个答案不起作用

db.users.updateMany({"devices.validity": {$gt: 0}}, {$inc: {validity: -1}});

价值未在数组中更新

I very beginner in MongoDB, I have collection called users

user 1:

{
  "_id": 1,
  "city_name": "Newyork",
  "device":[
    {
      "ime_number" : 1234343,
      "validity" : 40
    }
    ]
}

user 2:

{
  "_id": 2,
  "city_name": "London",
  "device":[
    {
      "ime_number" : 3434334,
      "validity" : 30
    }
    ]
}

I want to update all validity in collection is greater than zero validity decrement by 1

I tried this answer Not working

db.users.updateMany({"devices.validity": {$gt: 0}}, {$inc: {validity: -1}});

Value not updated in array

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

手心的海 2025-01-20 01:24:01

由于 device 是一个数组,因此

使用 arrayFilters$[] 过滤位置运算符进行更新。

db.users.updateMany({},
{
  $inc: {
    "device.$[device].validity": -1
  }
},
{
  arrayFilters: [
    {
      "device.validity": {
        $gt: 0
      }
    }
  ]
})

示例 Mongo Playground

As the device is an array,

Update with arrayFilters and $[<identifier>] filtered positional operator.

db.users.updateMany({},
{
  $inc: {
    "device.$[device].validity": -1
  }
},
{
  arrayFilters: [
    {
      "device.validity": {
        $gt: 0
      }
    }
  ]
})

Sample Mongo Playground

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文