对于数据库表中的重复记录,如何删除,下面来演示 我们先从以下例子来分析 --测试数据 /*----------------------------- select * from tt -----------------------------*/ id pid ----------- ----------- 1 1 1 1 2 2 3 3 3 3 3 3 (所影响的行数为 6 行) 首先,如何查询table中有重复记录 select *,count(1) as rownum from tt group by id, pid having count(1) > 1 id pid rownum ----------- ----------- ----------- 1 1 2 3 3 3 (所影响的行数为 2 行) 方法一:使用distinct和临时表 if object_id('tempdb..#tmp') is not null drop table #tmp select distinct * into #tmp from tt truncate table tt insert into tt select * from #tmp 方法二:添加标识列 alter table tt add NewID int identity(1,1) go delete from tt where exists(select 1 from tt a where a.newid>tt.newid and tt.id=a.id and tt.pid=a.pid) go alter table tt drop column NewID go --测试结果 /*----------------------------- select * from tt -----------------------------*/ id pid ----------- ----------- 1 1 2 2 3 3 (所影响的行数为 3 行) |
由中国名创www.chuang.top 整理发布。 |
国内虚拟主机租用
论坛网店虚拟主机租用
SQL数据库
- 网站建设指南
- 专业设计师为企业量身设计,一对一的服务,终身使用,维护简便。