How to keep track of a private messaging system using MongoDB?

后端 未结 3 515
南笙
南笙 2020-12-30 07:16

Take facebook\'s private messaging system where you have to keep track of sender and receiver along w/ the message content. If I were using MySQL I would have multiple table

相关标签:
3条回答
  • 2020-12-30 07:39

    Figured it out. See my explanation above in original post.

    0 讨论(0)
  • 2020-12-30 07:44
    Your Db Schema Should be like this->
    
    let chatImages = {
        original  : {type:String,required:true,trim:true},
        thumbnail : {type:String,required:true,trim:true}
    };
    
    let Chats = new Schema({
        CommonId  : {type: String, trim: true, index: true, unique: true,sparse: true},
        senderId   : {type: Schema.Types.ObjectId,index: true,required:true,ref:'User'},
        receiverId : {type: Schema.Types.ObjectId,index: true,required:true,ref:'User'},
        messageId  : {type: String, trim: true, index: true, unique: true,sparse: true},
        isDeliver  : {type: Boolean, default: false},
        isSent     : {type: Boolean, default: true},
        chatType   : {
                     type: String,required:true,enum: [
                     Config.APP_CONSTANTS.DATABASE.CHAT_TYPE.TEXT,
                     Config.APP_CONSTANTS.DATABASE.CHAT_TYPE.IMAGE
                     ],default:Config.APP_CONSTANTS.DATABASE.CHAT_TYPE.TEXT},
        text       : {type: String, trim: true, index: true,sparse: true},
        sentAt     : {type:Number, default: Date.now,index:true,required: true},
        chatImage  : {type:chatImages},
    });
    

    CommonId is very Important if you want the screen like whatsApp where you can see the persons with whom you chat. 1)It Make Grouping very easy(with $groupBy).

    You can Generate CommonId by just Compare between receiverId and SenderId which is ascending put it CommonId

    I think its a nice Explaination

    0 讨论(0)
  • 2020-12-30 07:57

    You are going to need some kind of link between the two collections (users and messages).

    Personally, I would keep it simple and add two extra fields to track the id of the sender and recipient, something like this:

    {
        _id: /* whatever_id */,
        message_body: "This is the message",
        date_sent: 2010-04-20T10:35,
        sender_id: /*id_of_sender*/,
        recipient_id: /* id_of_recipient */
    }
    

    The sender_id and recipient_id fields would just hold value for the appropriate user (most likely some ObjectID instance, although you can assign whatever you like) which corresponds to the _id field for the appropriate entries in the users collection. You would be able to query these appropriately to grab the messages you are after (or count them, or whatever else).

    Another approach might be to effectively do the same thing, but to use a formal DBRef for the sender and recipient rather than just putting their IDs in. This would probably work just as well but I'd tend to go with the previous solution just because it is simpler and probably easier to query.

    Both solutions would need to do another round-trip to the DB to grab the appropriate user documents (for displaying the "from" and "to" names for example).


    Edit:
    It would appear I have misunderstood what you are trying to achieve - I didn't know Facebook messaging incorporated any concept of threading. However, the solution you have presented above looks sound. Personally, I'd stick in the IDs for the users rather than their names (alice & bob), but it looks pretty workable apart from that.

    0 讨论(0)
提交回复
热议问题