查询 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.JdbcOdbc...