为mysql中的每个会话选择会话的最后一条消息 [英] select last message of conversation for each conversation in mysql

查看:89
本文介绍了为mysql中的每个会话选择会话的最后一条消息的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我的查询:

SELECT *
  FROM messages_status mst
       INNER JOIN messages msg 
             ON mst.msg_id=msg.id
 WHERE mst.user_id = 1 
       AND mst.status NOT IN (0,3)
ORDER BY 
       msg.created_at DESC

将显示在此sqlfiddle中: http://sqlfiddle.com/#!2/be010/1/0

will show up in this sqlfiddle: http://sqlfiddle.com/#!2/be010/1/0

您有2个表:messages和message_status 首先包含消息数据,例如内容,sender_id,创建时间和对话ID. 第二个具有特定的用户味精状态,是已读取还是已删除.

You have there the 2 tables: messages and message_status first contains message data like content, sender_id, created time, and conversation id. Second has specific user msg status, is it read or deleted.

我想获取每个对话的最新消息

有什么想法吗?

推荐答案

检查一下:

SELECT *
  FROM messages_status mst
       INNER JOIN (SELECT messages.* FROM messages INNER JOIN (
                    SELECT sender_ID,conv_id,MAX(created_at) as maxtime FROM messages
                    GROUP BY sender_ID,conv_id) as t1 ON
                    t1.sender_id = messages.sender_id AND t1.conv_id = messages.conv_id AND 
                    t1.maxtime = messages.created_at) msg 
                    ON mst.msg_id=msg.id
WHERE mst.user_id = 1 AND mst.status NOT IN (0,3)
ORDER BY msg.created_at DESC

这是链接

这篇关于为mysql中的每个会话选择会话的最后一条消息的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆