MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Comment récupérer des clés distinctes dans un objet dans MongoDB

Vous pouvez utiliser le nouveau $objectToArrray dans 3.4.4 version pour convertir toutes les paires clé et valeur en tableaux de documents suivis de $unwind &$group avec $addToSet pour obtenir des clés distinctes

db.collection.aggregate([{$project: {indexation: {$objectToArray: "$indexation"}}}, {$unwind:"$indexation"}, {$group:{_id:null, keys:{$addToSet:"$indexation.k"}}}])

Pour la version inférieure, vous devez mettre à jour indexation pour ressembler à ci-dessous et et utiliser

db.collection.distinct("indexation.k")

 { "_id" : ObjectId("58fb35531eb5df245d5d434f"), "name" : "d1.html", "indexation" : [{ "k" : "Citroen", "v" : 1 }, { "k" : "Marca", "v" : 1 }]}