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

Verschachtelte MongoDB-Suche mit 3 Ebenen

Die Ursache Ihrer "Probleme" ist die zweite Aggregationsstufe - { $unwind: "$address" } . Es entfernt den Eintrag für die Partei mit _id: 4 (weil sein Adress-Array leer ist, wie Sie erwähnt haben) und zwei Datensätze für die Parteien _id: 1 erzeugt und _id: 5 (weil jeder von ihnen zwei Adressen hat).

  • Um das Entfernen von Parteien ohne Adressen zu verhindern, sollten Sie preserveNullAndEmptyArrays setzen Option von $unwind auf true setzen .

  • Um das Duplizieren von Parteien für ihre verschiedenen Adressen zu verhindern, sollten Sie $group hinzufügen Aggregationsphase zu Ihrer Pipeline. Verwenden Sie außerdem $project Stufe mit $filter Operator, um leere Adressdatensätze in der Ausgabe auszuschließen.

db.party.aggregate([{
  $lookup: {
    from: "address",
    localField: "_id",
    foreignField: "party_id",
    as: "address"
  }
}, {
  $unwind: {
    path: "$address",
    preserveNullAndEmptyArrays: true
  }
}, {
  $lookup: {
    from: "addressComment",
    localField: "address._id",
    foreignField: "address_id",
    as: "address.addressComment",
  }
}, {
  $group: {
    _id : "$_id",
    name: { $first: "$name" },
    address: { $push: "$address" }
  }
}, {
  $project: {
    _id: 1,
    name: 1,
    address: {
      $filter: { input: "$address", as: "a", cond: { $ifNull: ["$$a._id", false] } }
    } 
  }
}]);