dongmangwei3822 2019-08-19 14:48
浏览 20
已采纳

如何从用户所在的组中选择最后一条消息

I'm making a private chat system, and I want to make section "last messages from your conversations"

I really don't know how to do it. Im stuck at selecting messages

BASE ONE - members
id | conversationid | userid

BASE TWO - conversations
conversationid | name

BASE THREE - messages
id | conversationid | uid | message

I expect that: user is in conversations with id's: 1, 4, 5,9, 15 and there are selected messages from them - ordered by id

  • 写回答

1条回答 默认 最新

  • dougu1896 2019-08-19 15:01
    关注

    First you need to know what are the conversation for your user:

     SELECT conversation_id
     FROM members
     WHERE user_id = @user_id
    

    Now you need to find what is the last message id for each conversation

     SELECT conversation_id, MAX(id) as last_id
     FROM members
     JOIN messages
       ON members.conversation_id = messages.conversation_id
     WHERE user_id = @user_id
     GROUP BY conversation_id
    

    Now you need to find the message associated with each id:

    SELECT l.conversation_id, l.last_id, m.message
    FROM (
         SELECT conversation_id, MAX(id) as last_id
         FROM members
         JOIN messages
           ON members.conversation_id = messages.conversation_id
         WHERE user_id = @user_id
         GROUP BY conversation_id
        ) l
    JOIN messages m
      ON l.last_id = m.id
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?