我们有一个表来跟踪我们应用程序的用户之间发送的消息。每行都有一个 fromid
、toid
、messageid
和 datetime
。
我想计算相互通信的不同用户对的数量。另一种表达方式是对用户之间不同的“对话”进行计数,其中对话简单地定义为两个用户之间发送的一条或多条消息。因此,举一个具体的例子,一次对话可能是 Fred 向 Bob 发送 2 条消息,Bob 向 Fred 发送 3 条消息。
fromid toid messageid datetime
Fred Bob 123 2013-04-22 00:00:01
Bob Fred 135 2013-04-22 00:01:02
Fred Bob 238 2013-04-22 00:05:00
Bob Fred 300 2013-04-22 00:09:13
Bob Fred 312 2013-04-22 00:10:48
所有这些都只是 1 次对话。对此进行查询的有效方法是什么(表非常大)?
最佳答案
SELECT COUNT(DISTINCT LEAST(fromID, toID), GREATEST(fromID, toID)) TotalConversation
FROM messages
输出
╔═══════════════════╗
║ TOTALCONVERSATION ║
╠═══════════════════╣
║ 1 ║
╚═══════════════════╝
关于mysql - 计算发送/接收对的不同集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16181752/