用SQL语句删除重复记录的2种方法.txt

来源:互联网 发布:清朝历史书知乎 编辑:程序博客网 时间:2024/04/29 08:57
问题:如何把具有相同字段的记录删除,只留下一条。

2. 写sql语句实现下列查询
    (表)t
    a b(列)
    1 2
    1 3
    1 4
    2 1
    2 2
    3 1
    4 1
    5 3
    5 2
查询结果要求
a b
1 2
2 1
3 1
4 1
5 2
SQL结果:
select num1,min(num2)as num2 from t group by num1

 
例如:表test里有id,name字段,如果有name相同的记录只留下一条,其余的删除。name的内容不定,相同的记录数不定。
 
用SQL语句删除重复记录的四种方法:

方法1:
 
1、将重复的记录记入temp1表
 
select [标志字段id],count(*) into temp1 from [表名]group by [标志字段id]having count(*)>1


2、将不重复的记录记入temp1表
 
insert temp1select [标志字段id],count(*) from [表名]group by [标志字段id]having count(*)=1
 
3、作一个包含所有不重复记录的表
 
select * into temp2 from [表名]where 标志字段id in(select 标志字段id from temp1)

 
4、删除重复表:delete [表名]
 
5、恢复表
insert [表名]select * from temp2

6、删除临时表
drop table temp1drop table temp2
 
方法2:
declare @max integer,@id integerdeclare cur_rows cursor local for select id,count(*) from 表名 group by id having count(*) > 1open cur_rowsfetch cur_rows into @id,@maxwhile @@fetch_status=0beginselect @max = @max -1set rowcount @maxdelete from 表名 where id = @idfetch cur_rows into @id,@maxendclose cur_rowsset rowcount 0


注:set rowcount @max - 1表示当前缓冲区只容纳@max-1条记录,如果有十条重复的,就刪除10条,一定会留一条的。也可以写成delete from 表名。