今天是:
首 页信息查询网站SEO查询工具CSS编辑器建站素材
网海拾贝,电脑资讯,电脑快报,it资讯,网站建设资讯,教程基地
软件新闻
操作系统
Vista Winxp Win2003 Linux Windows综合
工具软件
系统工具 媒体工具 网络工具 杀毒软件 聊天
软件开发
C教程 C++ Java C# ASP.NET JSP PHP
数据库
Oracle MySQL DB2 SQL Server Sybase
安全
网络 病毒
办公应用
Word Excel Powerpoint Outlook 其他
平面设计
Photoshop Fireworks Coreldraw Flash Illustrator 3dsmax
网站运营
网站运营 网站优化 网站策划 策划书下载 建站心得 站长故事 网站盈利 网页制作 网页特效 建站素材 免费资源 QQ频道
  当前位置:首 页 >> 数据库栏 >> SQLServer >> SQL Server中删除重复数据的几个方法

SQL Server中删除重复数据的几个方法

  发布于2006-03-06 13:44 来源:网海拾贝

数据库的使用过程中由于程序方面的问题有时候会碰到重复数据,重复数据导致了数据库部分设置不能正确设置……
   方法一
declare @max integer,@id integer
declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) > 1
open cur_rows
fetch cur_rows into @id,@max
while fetch_status=0
begin
select @max = @max -1
set rowcount @max
delete from 表名 where 主字段 = @id
fetch cur_rows into @id,@max
end
close cur_rows
set rowcount 0

   方法二
   有两个意义上的重复记录,一是完全重复的记录,也即所有字段均重复的记录,二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。
   1、对于第一种重复,比较容易解决,使用
select distinct * from tableName
   就可以得到无重复记录的结果集。
   如果该表需要删除重复的记录(重复记录保留1条),可以按以下方法删除
select distinct * into #Tmp from tableName
drop table tableName
select * into tableName from #Tmp
drop table #Tmp

   发生这种重复的原因是表设计不周产生的,增加唯一索引列即可解决。
   2、这类重复问题通常要求保留重复记录中的第一条记录,操作方法如下
   假设有重复的字段为Name,Address,要求得到这两个字段唯一的结果集
select identity(int,1,1) as autoID, * into #Tmp from tableName
select min(autoID) as autoID into #Tmp2 from #Tmp group by Name,autoID
select * from #Tmp where autoID in(select autoID from #tmp2)

   最后一个select即得到了Name,Address不重复的结果集(但多了一个autoID字段,实际写时可以写在select子句中省去此列)

中查找“SQL Server中删除重复数据的几个方法”更多相关内容

中查找“SQL Server中删除重复数据的几个方法”更多相关内容



上一篇:编写安全的SQL Server扩展存储过程
下一篇:SQL Server日志清除的两种方法
最近更新 赞助商
·性能损伤SQL Server 2008的全文检索11-20
·如何使用 SQL Server 数据库查询累计值10-29
·MSSQL server数据库备份还原SQL语句10-28
·SQL Server 2005最后的升级:SP3年底发布10-24
·微软SQL Server 2008数据库中的新数据类型10-13
· 微软发布数据库SQL Server规划线路图和..10-13
·教你如何在SQL Server数据库中加密数据10-13
·在SQL Server 2008数据库中实现数据压缩09-19
·网友分析微软SQL Server 2008的精妙之处09-19
·免费SQL注入扫描程序09-18
·Microsoft RTM版本数据库SQL Server 200809-11

共有评论 0 条 网友评分 0分 查看所有评论


发表评论→ 学而不思则罔,思而不学则殆,请大胆发表你的见解。

输验证码:

您对此篇文章的评分:1分 2分 3分 4分 5分

  • 站内搜索
关键词

搜索方式

搜索范围

精确匹配
Baidu
网站首页 - 关于本站 - 网站地图 - 广告合作 - 站点声明 - RSS订阅 - 联系我们
Copyright © 2005 网海拾贝.[新ICP备05003216号]. All Rights Reserved .