首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MYSQL -在两列中选择dISTINCT值

MYSQL -在两列中选择dISTINCT值
EN

Stack Overflow用户
提问于 2016-05-10 17:58:13
回答 2查看 46关注 0票数 0

我想选择sender_id或receiver_id = 20的最后一次。让我给你举个简单的例子。

代码语言:javascript
运行
复制
Table:
sender_id   receiver_id     created_time
20            30              1
30            20              2
20            30              3
20            40              4
40            20              5
20            20              6
20            30              7
50            60              9

Result:
sender_id   receiver_id     created_time
40            20              5
20            30              7
EN

回答 2

Stack Overflow用户

发布于 2016-05-10 18:04:09

如下所示:

代码语言:javascript
运行
复制
SELECT LEAST(sender_id, receiver_id), 
       GREATEST(sender_id, receiver_id),
       MAX(created_time)
FROM mytable
WHERE 20 IN (sender_id, receiver_id)
GROUP BY LEAST(sender_id, receiver_id), 
         GREATEST(sender_id, receiver_id)

上面的查询为条目(20, 20, 6)生成一条额外的记录。如果希望排除具有相同sender_idreceiver_id的记录,可以在WHERE子句中添加一个额外的谓词。

票数 0
EN

Stack Overflow用户

发布于 2016-05-10 18:21:49

尝试以下代码:

代码语言:javascript
运行
复制
SELECT * FROM new_table AS t1
WHERE
(sender_id = 20 OR receiver_id = 20)
AND
(t1.created_time >= 
 (SELECT MAX(created_time) FROM new_table WHERE sender_id = t1.sender_id)
)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37135132

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档