有一个表如下:
想要的查询结果为:
即根据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 【提问】基于Invest的水源涵养
- ¥20 微信网友居然可以通过vx号找到我绑的手机号
- ¥15 寻一个支付宝扫码远程授权登录的软件助手app
- ¥15 解riccati方程组
- ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
- ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
- ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
- ¥50 树莓派安卓APK系统签名
- ¥65 汇编语言除法溢出问题