如何删除表中重复的纪录

有test表如下:如何删除表中重复的纪录

pri   name

111  aaa

222  bbb

333  ccc

111  aaa

222 bbb

333 ccc

方法一:使用distinct和临时表

select  distinct * into temp from  testtable
delete  from  testtable
insert into testtable  select * from  temp

 

方法二:添加标识列

select  *from  testtable
alter table testtable add newid int identity(1,1)
go 
delete from  testtable    where exists(
select 1 from  testtable  a where  a.newid>testtable .newid
and testtable.pri=a.pri and testtable.name=a.name)

go
alter table testtable  drop column newid
go

另外一篇文章搜藏

http://blog.csdn.net/xiaojianpitt/archive/2007/11/29/1906959.aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值