删除数据库表中的重复数据

代码

    delete from tbl where (id) in(
    select id from (

    select id from tbl where (name,age) in
         (
        select name,age from tbl group by name,age  having count(*)>1
        )
        and id not in (
        select min(id) from tbl group by name,age having count(*)>1
        )
    )tbl
)

详解

  • 1
select name,age from tbl group by name,age  having count(*)>1

搜索名字和年龄相同的数据

  • 2
select min(id) from tbl group by name,age having count(*)>1

搜索出名字和年龄相同的数据中id最小的列

  • 3
select id from tbl where (name,age) in
         (
        select name,age from tbl group by name,age  having count(*)>1
        )
        and id not in (
        select min(id) from tbl group by name,age having count(*)>1
        )

将第一句sql和第二句sql合并 not in 表示排除,
产生一个新的所有符合标准的id所有值

  • 4
select id from (

    select id from tbl where (name,age) in
         (
        select name,age from tbl group by name,age  having count(*)>1
        )
        and id not in (
        select min(id) from tbl group by name,age having count(*)>1
        )
    )tbl

由于在mysql中,必须要在外部再包含一个sql 所以这个不能少

  • 5
delete from tbl where (id) in(
    select id from (

    select id from tbl where (name,age) in
         (
        select name,age from tbl group by name,age  having count(*)>1
        )
        and id not in (
        select min(id) from tbl group by name,age having count(*)>1
        )
    )tbl
)

最后 所有符合标准的id 全部删除即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值