SQL语句删除重复记录

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

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


2、将不重复的记录记入temp1表
 
insert temp1
select [标志字段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 temp1
drop table temp2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

丁码农

请作者喝杯咖啡

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值