sql >> Database teknologi >  >> NoSQL >> MongoDB

Sådan får du den sidste besked fra chatsamtale i mongodb

Problemet er, hvordan meddelelser stored .

Data gemt:

fromUser 123 and toUser 456
fromUser 456 and toUser 123
 

Så når du grupperer det, er de logisk set ens , men not for grouping .

Løsning:

Vi skal sikre, at afsender/modtager altid kommer på samme måde

1. Create array where we store sender / receiver 2. Order that array `[123, 456] [456, 123] => [123,456], [123,456]` 3. Group by this ordered array (In Mongo way: $project, $unwind, $sort, $group - push)
db.chats.aggregate([
  {
    $match: {
      $or: [
        {
          "toUser": 123
        },
        {
          "fromUser": 123
        }
      ]
    }
  },
  {
    "$project": {
      toUser: 1,
      fromUser: 1,
      message: 1,
      timeStamp: 1,
      fromToUser: [
        "$fromUser",
        "$toUser"
      ]
    }
  },
  {
    $unwind: "$fromToUser"
  },
  {
    $sort: {
      "fromToUser": 1
    }
  },
  {
    $group: {
      _id: "$_id",
      "fromToUser": {
        $push: "$fromToUser"
      },
      "fromUser": {
        "$first": "$fromUser"
      },
      "toUser": {
        "$first": "$toUser"
      },
      "message": {
        "$first": "$message"
      },
      "timeStamp": {
        "$first": "$timeStamp"
      }
    }
  },
  {
    "$sort": {
      "timeStamp": -1
    }
  },
  {
    "$group": {
      "_id": "$fromToUser",
      "fromUser": {
        "$first": "$fromUser"
      },
      "toUser": {
        "$first": "$toUser"
      },
      "message": {
        "$first": "$message"
      },
      "timeStamp": {
        "$first": "$timeStamp"
      }
    }
  }
])
 

Resultat

[
  {
    "_id": [
      101,
      123
    ],
    "fromUser": 123,
    "message": "Kk",
    "timeStamp": "2019-10-09 18:31:12:1212 PM +05:30",
    "toUser": 101
  },
  {
    "_id": [
      123,
      456
    ],
    "fromUser": 123,
    "message": "2",
    "timeStamp": "2019-10-09 18:31:21:2121 PM +05:30",
    "toUser": 456
  }
]
 

MongoPlayground




  1. spring-data-mongodb giver undtagelse for mongodb-godkendelse

  2. Mongoose - kan du ikke få adgang til objektegenskaber?

  3. Indsættelse af den aktuelle dato og klokkeslæt i mongodb

  4. Mærkeligt svar, når man finder dokumenter i MongoDB ved hjælp af Mongoose i Node.js