MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

Die Mongoose-Aggregationsabfrage gibt mehr als einen Datensatz zurück, wenn sie nur einen zurückgeben sollte

Ändern Sie die qroup-Pipeline genauso wie

Sie müssen nach Absender gruppieren, nicht nach eindeutiger _id

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

Und in $project

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