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

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 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作