微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

删除嵌套数组mongodb中的对象

如何解决删除嵌套数组mongodb中的对象

我有点像 mongo 中的下一个 json。

我的目标是用 "id_s": "1"

删除所有嵌套对象
{
  "_id": "5150a1199fac0e6910000002","name": "some name","p_a": [
    {
      "sub_name": "subname"
    },{
      "sub_name": "subname2","p_p": [
        {
          "last_level": "toDelete","id_s": "1"
        },{
          "last_level": "toKeep","id_s": "2"
        }
      ]
    },{
      "sub_name": "subname3","id_s": "2"
        }
      ]
    }
  ]
}

预期的 JSON:

{
  "_id": "5150a1199fac0e6910000002","p_p": [
        {
          "last_level": "toKeep","id_s": "2"
        }
      ]
    }
  ]
}

解决方法

这将为您提供 id_s: 2 位置的文档并忽略其余部分。

db.getCollection("test").aggregate(
[
    { 
        "$match" : { 
            "_id" : ObjectId("5150a1199fac0e6910000002")
        }
    },{ 
        "$unwind" : { 
            "path" : "$p_a"
        }
    },{ 
        "$unwind" : { 
            "path" : "$p_a.p_p"
        }
    },{ 
        "$match" : { 
            "p_a.p_p.id_s" : "2"
        }
    }
],{ 
    "allowDiskUse" : false
}

);

输出:

  /* 1 */
{
    "_id" : ObjectId("606d83fe44c9fc09f60d0756"),"name" : "some name","p_a" : {
        "sub_name" : "subname2","p_p" : {
            "last_level" : "toKeep","id_s" : "2"
        }
    }
}

/* 2 */
{
    "_id" : ObjectId("606d83fe44c9fc09f60d0756"),"p_a" : {
        "sub_name" : "subname3","id_s" : "2"
        }
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?