Sie können das neue $objectToArray
verwenden in 3.4.4
Version, um alle Schlüssel- und Wertpaare in Dokumentarrays zu konvertieren, gefolgt von $unwind
&$group
mit $addToSet
um unterschiedliche Schlüssel zu erhalten
db.collection.aggregate([{$project: {indexation: {$objectToArray: "$indexation"}}}, {$unwind:"$indexation"}, {$group:{_id:null, keys:{$addToSet:"$indexation.k"}}}])
Für niedrigere Versionen müssen Sie die indexation
aktualisieren wie unten aussehen und
db.collection.distinct("indexation.k")
{ "_id" : ObjectId("58fb35531eb5df245d5d434f"), "name" : "d1.html", "indexation" : [{ "k" : "Citroen", "v" : 1 }, { "k" : "Marca", "v" : 1 }]}