删除一张表中重复数据并保留一条ID最小的记录
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了删除一张表中重复数据并保留一条ID最小的记录相关的知识,希望对你有一定的参考价值。
参考技术A 表结构为最简单的user表,递增的id,可能重复username。首先我们来看一下查找名字重复的所有记录:
如果我们现在的要求是把所有重复的记录都删了,那么SQL语句为:
执行结果为:
无法在FROM子句中为更新指定目标表“user”,就是无法在删除时同时查询这张表,这个问题只在mysql中出现,oracle没有。怎么解决?我们只需要在查出结果以后加一张中间表。让执行器认为我们要查的数据不是来自正在删的这张表就可以了。
现在删除所有重复数据数据做完了,考虑怎么保留重复数据中id最小的。只需要在删除时让删除该条的记录id不在重复数据id最小的当中就可以了。
执行前表数据:
执行后表数据:
数据库怎样删除多条重复数据保留一条?
delete 表A where 重复的列名(可以是多列) in (select 重复的列名(可以是多列) from 表A group by 重复的列名(可以是多列) having (count(1)>1) ) where rowid!=(select min(rowid) from 表A group by 重复的列名(可以是多列)having (count(1)>1));删除重复的数据,留下rowid最小的那条! 参考技术A 一张表里面以两个字段为唯一字段,当几条记录的这两个字段完全相同时,需要删除重复项,如下表:
a b c d
1 2 3 4
1 5 3 5
1 2 7 9
以a、b为唯一字段,第一条和第三条的a、b完全相同,所以,需要删除第一条记录1 2 3 4 或者第三条记录1 2 7 9
即如下结果:
a b c d
1 2 3 4
1 5 3 5
或
a b c d
1 5 3 5
1 2 7 9
以上是关于删除一张表中重复数据并保留一条ID最小的记录的主要内容,如果未能解决你的问题,请参考以下文章