yewanji 2023-03-10 15:29 采纳率: 36.3%
浏览 15

mongodb 如何批量修改子集数据

假如mongodb 有上面一个集合,我要将年纪为18岁的员工批量将其逻辑删除,请问mongo sql如何写
我发现这个写法只会更新一条
db.company.updateMany({"staff.age":18},{$set:{"staff.$.deleted": true}})

{
    "_id" : ObjectId("63da119f07781d41000431b8"),
    "name" : "公司1",
    "staff" : [
        {
            "name" : "张三",
            "age" : 18,
            "deleted" : false
        },
        {
            "name" : "李四",
            "age" : 18,
            "deleted" : false
        }
    ]
}
  • 写回答

1条回答 默认 最新

  • 老码识途呀 .Net领域优质创作者 2023-03-10 15:56
    关注

    可以设置{multi:true},此属性默认为false,只更新满足条件的第一条数据,设置为true,即可更新全部满足条件的数据

    评论

报告相同问题?

问题事件

  • 创建了问题 3月10日

悬赏问题

  • ¥15 可以实现这个有不同背景颜色的九九乘法表吗?
  • ¥50 python写segy数据时出错2
  • ¥20 关于R studio 做精确稳定检验的问题!(语言-r语言)
  • ¥50 用贝叶斯决策方法,设计CAD程序
  • ¥20 关于#目标检测#的问题:(qq收集表到时间才能填写,填写的份数有上限)
  • ¥50 ZYNQ7020双核FLAHS烧写的问题
  • ¥20 ue 5 中想要实现第一人称人物左右行走摆动的效果,摄像头只向右摆动一次(关键词-结点)
  • ¥15 AD9164瞬时带宽1.8G,怎么计算出来?
  • ¥15 鼠标右键,撤销删除 复制 移动,要怎样删除? HKEY_CLASSES_ROOT*\shellex\ContextMenuHandlers 没用
  • ¥15 服务器安装php5.6版本