mysql - 如何获取多列不同值并且每个不同字段具有相同的反向数据

标签 mysql

我有一个包含 3 列的表,名为 msg、发送者和接收者。现在我需要获得不同的发送者和接收者。但在这里,如果我有发送者 a 和接收者 b 或发送者 b 和接收者 a,它会向我显示两者。但我只想要最后一个。

msg | sender | receiver
hi  | 1      | 5
he  | 2      | 6
jh  | 5      |1

SELECT DSTINCT `sender`, `receiver` from `table`

它给了我这个结果

1-5
2-6
5-1

但我需要

5-1
2-6

有什么sql查询可以解决这个问题吗?

最佳答案

当然,让我们使用整数这一事实,并且始终将较小的数放在第一列,将较大的数放在右列

SELECT DISTINCT
  CASE WHEN sender < receiver THEN sender ELSE receiver END as PartyA,
  CASE WHEN sender < receiver THEN receiver ELSE sender END as PartyB
from `table`

它并不完全产生 5-1 (它产生 1-5),但我认为你并不真正关心,你只是想要进行对话的人的唯一列表,并且 5-1 == 1- 5

关于mysql - 如何获取多列不同值并且每个不同字段具有相同的反向数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56375985/

相关文章:

mysql - MySQL TRIGGER 可以单独检查所有 INSERT 值吗?

mysql - 如何更改 MySQL 中的 SHOW GRANTS 标题?

mysql - 在 join mysql 中合并三个表

mysql - 批量删除超过 1 小时的表所需的存储过程

php - 从数据库检索数据到下拉列表

mysql - Devise 和country_select gem 不会将选择保存到数据库 Rails4 中

mysql - mysql中的 '!='和 '<>'有什么区别

mysql - Laravel 迁移 - 违反完整性约束 : 1452 Cannot add or update a child row: a foreign key constraint fails

javascript - 如果选中/取消选中,如何条件数据表复选框

mysql - Magento SQLSTATE [HY000] : General error: 2006 MySQL