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

MongoDB. Définir un numéro unique pour chaque document de la collection

Expérimentalement (selon la taille de votre collection) vous pouvez essayer d'utiliser $unwind qui prend un includeArrayIndex paramètre :

db.collection.aggregate([
    {
        $group: {
            _id: null,
            docs: { $push: "$$ROOT" }
        }
    },
    {
        $unwind: {
            path: "$docs",
            includeArrayIndex: "index"
        }
    },
    {
        $replaceRoot: {
            newRoot: {
                $mergeObjects: [ "$docs", { place: "$index" } ]
            }
        }
    }
])

Mongo Playground

Vous pouvez également envisager $out pour remplacer la collection existante par le résultat d'agrégation ci-dessus