sql >> Databasteknik >  >> NoSQL >> MongoDB

Ta bort dubbletter av dokument baserat på fält

Detta är något vi faktiskt kan göra med hjälp av aggregeringsramverket och utan bearbetning på klientsidan.

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. Bädda in meddelandesvar i meddelandeförälder med mongodb med mongoid

  2. MongoDB -- stort antal databaser

  3. Mongo unika index okänslig för skiftläge

  4. Så här gör du:Använd HBase Thrift Interface, del 1