删除表里重复数据

Posted

tags:

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

  • 介绍

使用sql删除数据库中的重复数据

  • 1、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断
    select   *   from   people
    where   peopleId   in   (select     peopleId     from     people     group     by     peopleId     having     count(peopleId)   >   1)

    2、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录
    delete   from   people
    where   peopleId     in   (select     peopleId     from   people     group     by     peopleId       having     count(peopleId)   >   1)
    and   rowid   not   in   (select   min(rowid)   from     people     group   by   peopleId     having   count(peopleId   )> 1)

    3、查找表中多余的重复记录(多个字段)
    select   *   from   vitae   a
    where   (a.peopleId,a.seq)   in     (select   peopleId,seq   from   vitae   group   by   peopleId,seq     having   count(*)   >   1)

    4、删除表中多余的重复记录(多个字段),只留有rowid最小的记录
    delete   from   vitae   a
    where   (a.peopleId,a.seq)   in     (select   peopleId,seq   from   vitae   group   by   peopleId,seq   having   count(*)   >   1)
    and   rowid   not   in   (select   min(rowid)   from   vitae   group   by   peopleId,seq   having   count(*)> 1)

    5、查找表中多余的重复记录(多个字段),不包含rowid最小的记录
    select   *   from   vitae   a
    where   (a.peopleId,a.seq)   in     (select   peopleId,seq   from   vitae   group   by   peopleId,seq   having   count(*)   >   1)
    and   rowid   not   in   (select   min(rowid)   from   vitae   group   by   peopleId,seq   having   count(*)> 1)

以上是关于删除表里重复数据的主要内容,如果未能解决你的问题,请参考以下文章

Oracle中如何删除重复数据

如何用sql 语句查找一个表里的两个字段重复的记录

excel表格去重怎么操作

oracle数据库怎么删除重复数据只留一个?

arcgis如何批量删除重复面?

MySql怎么查询重复的数据