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

La requête d'agrégation Mongoose renvoie plusieurs enregistrements alors qu'elle ne devrait en renvoyer qu'un seul

Modifier le pipeline qgroup comme

Vous devez regrouper par expéditeur et non par _id unique

{
          $group: {
            _id: "$sender",
            sender: {
              $first: "$sender"
            },
            messageId: {
              $first: "$_id"
            },
            text: {
              $first: "$text"
            },
            date: {
              $first: "$date"
            },
            unread: {
              $first: "$unread"
            }
          }
        }

Et changer dans $project

$project: {
            sender: 1,
            _id: "$messageId",
            text: 1,
            date: 1,
            unread: 1
          }