sql >> Database >  >> NoSQL >> MongoDB

Verwijder dubbele documenten op basis van veld

Dit is iets dat we kunnen doen met behulp van het aggregatieraamwerk en zonder verwerking aan de kant van de klant.

MongoDB 3.4

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

)

MongoDB-versie <=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. Een document vinden op ingesloten item in MongoDB PHP

  2. Hoe voer je een upsert uit in Mongoose op zoek naar een ingesloten document?

  3. docker-compose:verbinding geweigerd tussen containers, maar service toegankelijk vanaf host

  4. MongoDB-aggregatie over een bereik