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

Trouver des enregistrements en double dans MongoDB

Utiliser l'agrégation sur name et obtenez name avec count > 1 :

db.collection.aggregate([
    {"$group" : { "_id": "$name", "count": { "$sum": 1 } } },
    {"$match": {"_id" :{ "$ne" : null } , "count" : {"$gt": 1} } }, 
    {"$project": {"name" : "$_id", "_id" : 0} }
]);

Pour trier les résultats du plus au moins de doublons :

db.collection.aggregate([
    {"$group" : { "_id": "$name", "count": { "$sum": 1 } } },
    {"$match": {"_id" :{ "$ne" : null } , "count" : {"$gt": 1} } }, 
    {"$sort": {"count" : -1} },
    {"$project": {"name" : "$_id", "_id" : 0} }     
]);

Pour utiliser avec un autre nom de colonne que "name", changez "$name " à "$column_name "