select distict * into #tmp from yourtabletruncate yourtableinsert yourtable select * from #tmp
解决方案 »
- Debug错误问题材
- 关于获取表索引的创建语句
- 在sql2000里面用什么可以代替Row_Number() over呢?
- 寻求帮助,数据库设计规范最新版是哪个版本?
- SQL语句分类问题
- [11.16]触发器中, 如何获取INSERT, DELETE中的某个字段中的值
- 请教一个sql语句!
- 交叉表问题
- 使用"本地系统帐户"和使用"域用户帐户"区别是什么,怎么更改?
- 在DELPHI中调用在SQL SERVER2000中编写的存储过程,出了点错,请各位过来指点一二(100分酬谢)
- 如何完整的卸载MS SQL Server 2000 在线等待,急,急,急……
- 存储过程的参数问题,有代码,请大家帮忙看看。
删除重复数据一、具有主键的情况
a.具有唯一性的字段id(为唯一主键)
delect table
where id not in
(
select max(id) from table group by col1,col2,col3...
)
group by 子句后跟的字段就是你用来判断重复的条件,如只有col1,
那么只要col1字段内容相同即表示记录相同。b.具有联合主键
假设col1+','+col2+','...col5 为联合主键
select * from table where col1+','+col2+','...col5 in (
select max(col1+','+col2+','...col5) from table
where having count(*)>1
group by col1,col2,col3,col4
)
group by 子句后跟的字段就是你用来判断重复的条件,
如只有col1,那么只要col1字段内容相同即表示记录相同。
or
select * from table where exists (select 1 from table x where table.col1 = x.col1 and
table.col2= x.col2 group by x.col1,x.col2 having count(*) >1)c:判断所有的字段
select * into #aa from table group by id1,id2,....
delete table
insert into table
select * from #aa二、没有主键的情况a:用临时表实现
select identity(int,1,1) as id,* into #temp from ta
delect #temp
where id not in
(
select max(id) from # group by col1,col2,col3...
)
delete table ta
inset into ta(...)
select ..... from #tempb:用改变表结构(加一个唯一字段)来实现
alter table 表 add newfield int identity(1,1)
delete 表
where newfield not in
(
select min(newfield) from 表 group by 除newfield外的所有字段
)alter table 表 drop column newfield
select 两行中的一行 into #tmp from yourtbl
delete 两行 from yourtbl
insert into yourtbl select * from #tmp
drop #tmp