删除重复数据,只保留ID最小的一条数据

Posted 任楚娴

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了删除重复数据,只保留ID最小的一条数据相关的知识,希望对你有一定的参考价值。

最近遇到一个问题,就是使用的rm_user_department的重复数据过多,需要删除重复数据,在网上找的sql,照着写的基本上运行都有错误,现在将自己写的贴出来给大家看看.

rm_user_department 的表结构如图:

select * from rm_user_department

 

DELETE
FROM
    rm_user_department  --这里不能使用别名,如果使用别名会报错
WHERE
    (
        user_id,
        dep_id,
        user_type
    ) IN (

select a.userID,a.depId,a.user_type from ( -- 这里需要套一层a,如果去掉这个a,会报错: You can\'t specify target table \'rm_user_department\' for update in FROM clause

        SELECT
            user_id as userID,
            dep_id as depId,
            user_type --     COUNT(*)
        FROM
            rm_user_department
        GROUP BY
            user_id,
            dep_id,
            user_type
        HAVING
            COUNT(*) > 1
) a 
    )
AND id NOT IN (
SELECT b.id from ( -- 这里b和上面的a是同理
    SELECT
        MIN(tt.id) AS id
    FROM
        rm_user_department tt
    GROUP BY
        user_id,
        dep_id,
        user_type
    HAVING
        COUNT(*) > 1
) b
);

 大家使用的时候,只需要将我的代码复制下来,将表名改一下就好啦

以上是关于删除重复数据,只保留ID最小的一条数据的主要内容,如果未能解决你的问题,请参考以下文章

Mysql删除重复记录,保留id最小的一条

mysql 删除重复的数据保留一条

Mysql 删除重复记录,只保留最小的一条

sql删除重复数据且只保留一条?

删除一张表中重复数据并保留一条ID最小的记录

MySQL删除重复数据只保留一条