有一个表如下:
想要的查询结果为:
即根据num1和num2这两个字段进行去重,不论它们的先后顺序。比如:num1=111111,num2=123123和num1=123123,num2=111111就是重复的,去重并保留一条记录。

MySQL根据两列进行去重
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
7条回答 默认 最新
- 路漫漫兮其修远兮 2018-09-13 09:42关注
这个是ID是自增序列的做法,有点复杂,如果你的ID是UUID的话这个方式还是有问题。
SELECT * FROM tt WHERE ID NOT IN ( SELECT * FROM ( SELECT t1.ID FROM tt AS t1 INNER JOIN tt AS t2 ON t1.a = t2.b AND t1.b = t2.a AND t1.ID != t2.ID GROUP BY t1.id + t2.id ) AS t )
如果按照这个写法中途遇到了group by的错误执行下面语句
-- 修改mysql中的group by 要求查询字段全部在group by后的设置
set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'; set session sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
如果不是自增ID的话,我在想想还有什么别的写法
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报