有一个表如下:
想要的查询结果为:
即根据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的话,我在想想还有什么别的写法
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 请教一下各位,为什么我这个没有实现模拟点击
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记
- ¥15 保护模式-系统加载-段寄存器
- ¥15 电脑桌面设定一个区域禁止鼠标操作