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
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)