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

Comment exécuter l'agrégat dans mongodb dans le framework laravel

Vous pouvez accéder à la méthode d'agrégation sur la bibliothèque Jenssegers via le raw() fonction.

Voici un exemple d'appel agrégé avec group, sort, limit et project. Vous pouvez l'adapter à vos besoins :

//Perform an aggregate function and get a cursor
$cursor = Data::raw()->aggregate([
    ['$group' =>
        ['_id' => '$name', 'count' => ['$sum' => 1]]
    ],
    ['$sort' => ['count' => -1]],
    ['$limit' => 30],
    ['$project' => ['_id' => 0,
                   'text' => '$_id',
                   'size' => '$count',
                   ]
    ],
]);

//Iterate your cursor
$current = $cursor;
do {
    echo $current; //Process each element
} while (!($current = $cursor->next()));

Notez que l'utilisation de raw() nécessite l'utilisation d'un curseur car il s'agit d'un appel de bas niveau.