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

查询 MongoDB 嵌套文档并找到完全匹配的内部对象,使其过滤器之一将其自己的字段值作为条件

如何解决查询 MongoDB 嵌套文档并找到完全匹配的内部对象,使其过滤器之一将其自己的字段值作为条件

我在 Mongo 集合中有以下文档。

{
   "_id":"112211","student":{
      "student_display_name":"Siva","first_name":"Siva","last_name":"Ram","age":"20","department":"IT","section":"D","edit_sequence":"2","unique_id":"siva_2","address":{
         "data":[
            {
               "student_display_name":"Siva","student_id":"siva_2","street":"Perter's Park","area":"BMS Road","pincode":"560001"
            },{
               "student_display_name":"Siva","student_id":"siva_1","street":"St.Mary's Colony","student_id":"siva_0","street":"MG Colony","pincode":"560001"
            }
         ]
      },"student":{
         "data":[
            {
               "student_display_name":"Siva","section":"B","edit_sequence":"1","unique_id":"siva_1"
            },"section":"A","edit_sequence":"0","unique_id":"siva_0"
            }
         ]
      }
   },"college":"student college","root_table":"student"
}

从此文档中,我需要使用以下匹配过滤器进行查询

{
   "$match":{
      "$or":[
         {
            "student.address.data.pincode":"560001"
         },{
            "$and":[
               {
                  "student.address.data.data.last_name":"Siva"
               },{
                  "student.address.data.data.first_name":"Ram"
               }
            ]
         }
      ]
   }
}

使用这些匹配过滤器,此外, 我们将获得 address.data 数组下的所有 3 个对象。 但是,从这些结果中,我想根据“student.unique_id like student.address.data.student_id = student.unique_id”值进一步过滤,这样我只会得到如下匹配项。

这是我想要的最终结果。

 {
       "address":{
                   "student_display_name":"Siva","pincode":"560001"
                }
    }

如何在 MongoDB 中实现这一点?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 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”。这是什么意思?