MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

Rufen Sie mehrere abgefragte Elemente in einem Objektarray in der MongoDB-Sammlung ab

Sie können $redact verwenden Betreiber:

db.buildings.aggregate([
{$match:{"zone.AHU":{$exists:true}}},
{$redact:{
  $cond:{
       if:{$or:[{$eq:["$AHU","C"]},{$not: "$AHU"}]},
       then:"$$DESCEND",
       else:"$$PRUNE"   
     }  
   }}  
]) 

Merken Sie sich {$not: "$AHU"} Es ist wichtig, dass es eingeschlossen wird, damit das obere Element nicht ausgeschlossen wird. Wenn es nicht hinzugefügt wird, wird das oberste Element übersprungen und somit das gesamte eingebettete Dokument übersprungen.

Ausgabe:

{
"_id" : ObjectId("5aba4460a042dc4a2fdf26cd"),
"name" : "Test Street",
"coordinate" : [ 
    12, 
    31
],
"yearlyEnergyCost" : 1444,
"zone" : [ 
    {
        "name" : "AHU-C-Z2",
        "_id" : ObjectId("5aba4460a042dc4a2fdf26ce"),
        "AHU" : "C",
        "precooling" : [],
        "subZone" : []
    }, 
    {
        "name" : "AHU-C-Z1",
        "AHU" : "C",
        "_id" : ObjectId("5ac09c898249affa03506eff"),
        "precooling" : [],
        "subZone" : []
    }, 
    {
        "name" : "AHU-C-Z3",
        "AHU" : "C",
        "_id" : ObjectId("5ac09c898249affa03506efe"),
        "precooling" : [],
        "subZone" : []
    }
],
"__v" : 2
}