sql >> Database teknologi >  >> NoSQL >> MongoDB

Fjern duplikerede dokumenter baseret på felt

Dette er noget, vi faktisk kan gøre ved hjælp af aggregeringsrammerne og uden behandling på klientsiden.

MongoDB 3.4

db.collection.aggregate(
    [ 
        { "$sort": { "_id": 1 } }, 
        { "$group": { 
            "_id": "$asin", 
            "doc": { "$first": "$$ROOT" } 
        }}, 
        { "$replaceRoot": { "newRoot": "$doc" } },
        { "$out": "collection" }
    ]

)

MongoDB version <=3.2:

db.collection.aggregate(
    [ 
        { "$sort": { "_id": 1 } }, 
        { "$group": { 
            "_id": "$asin", 
            "doc": { "$first": "$$ROOT" } 
        }}, 
        { "$project": { 
            "asin": "$doc.asin", 
            "url": "$doc.url", 
            "image": "$doc.image", 
            "salesRank": "$doc.salesRank", 
            "title": "$doc.salesRank", 
            "brand": "$doc.brand", 
            "favourite": "$doc.favourite", 
            "createdAt": "$doc.createdAt", 
            "updatedAt": "$doc.updatedAt" 
        }},
        { "$out": "collection" }
    ]
)


  1. Hvordan registreres ClassMap for alle klasser i et navneområde for MongoDb?

  2. MongoDB sorterer dokumenter efter array-elementer

  3. Hvordan matcher man aggregerede ($graphLookup) elementer i MongoDB?

  4. Installer MongoDB på Windows