saltor 2018-09-13 02:41 采纳率: 100%
浏览 6342
已采纳

MySQL根据两列进行去重

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

  • 写回答

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的话,我在想想还有什么别的写法

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?

悬赏问题

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