sql >> Base de Datos >  >> NoSQL >> MongoDB

La consulta de agregación de Mongoose devuelve más de un registro cuando debería devolver solo uno

Cambiar la canalización de qroup como

Debe agrupar por remitente, no por _id único

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

Y cambio en $proyecto

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