当前位置:首页 > 系统运维 > 正文内容

SQL Server重复数据删除的两种 ***

a8116255316年前 (2010-07-01)系统运维5

此文章主要讲述的是正确删除SQL Server重复数据的2 *** ,我们大家都知道数据库在使用的实际操作过程中,往往因为程序方面的问题,而碰到这些问题,例如,SQL Server重复数据,重复数据导致了数据库部分设置不能正确设置……

删除SQL Server重复数据 *** 一

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 

删除SQL Server重复数据 *** 二

有两个意义上的重复记录:

一是完全重复的记录,也即所有字段均重复的记录,

二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。

A、对于之一种重复,比较容易解决,使用

select distinct * from tableName

就可以得到无重复记录的结果集。

假如该表需要删除重复的记录(重复记录保留1条),可以按以下 *** 删除

select distinct * into #Tmp from tableName  drop table tableName  select * into tableName from #Tmp  drop table #Tmp 

发生这种重复的原因是表设计不周产生的,增加唯一索引列即可解决。

B、这类重复问题通常要求保留重复记录中的之一条记录,操作 *** 如下

假设有重复的字段为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重复数据的2个介绍,望你能有所收获。

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://2345hao.cn/blog/index.php/post/21404.html

分享给朋友:

“SQL Server重复数据删除的两种 *** ” 的相关文章

windows 7鼠标停顿怎么办?windows 7 usb鼠标停顿的原因以及解决

windows 7鼠标停顿怎么办?windows 7 usb鼠标停顿的原因以及解决

很多使用Windows 7系统的朋友都想小编反应,假如暂停使用电脑,鼠标会出现停顿现象,这是怎么回事呢 该怎么解决呢 下面就和小编一起去看下Windows 7 usb鼠标停顿的解决方法吧。 由于Windows 7系统中有一项USB选择性暂停造成的。这项设置主要为了节电,当他检测到用户没有对系统进行...

上帝不止一个 更多Windows7 快捷模式.

上帝不止一个 更多Windows7 快捷模式.

国外媒体CNET NEWS就这个“上帝模式”和微软Windows部门主管Steven Sinofsky进行邮件交流后得知,这其实只是众多快捷方式中的一个,Sinofsky在邮件里给出了十多个这类快捷方式的关键字符串。 它们的建立方法和之前的“上帝模式”一样,在任意位置新建的一个文件夹,然后改名即可...

windows 7系统开机后出现黑屏提示Windows无法启动

windows 7系统开机后出现黑屏提示Windows无法启动

一些用户的Windows 7系统开机后出现黑屏,代码为 Windows无法启动: WindowsSystem32ConfigSystem”。这个问题该如何修复呢?现在小编就给大家分析一下吧。 其实这个代码的意思是引导文件丢失了,引导文件(NTLDR)一般存放于C盘根目录下,是一个具有隐藏和只读属性...

windows 7系统怎么取消禁ping命令?

windows 7系统怎么取消禁ping命令?

当我在虚拟机的linux系统中ping本机的ip发现ping不通,而本机可以ping通虚拟机中的ip。应该是出于安全考虑吧,Windows 7默认在防火墙里禁止了。 1、查看主机ip 打开“开始”程序中的“附件”,找到“命令提示符”打开。输入命令:ipconfig,可以看到本机的ip是192.1...

windows 7旗舰版系统提示应用程序错误代码0xc0000409的故障原因

windows 7旗舰版系统提示应用程序错误代码0xc0000409的故障原因

问题现象,具体如下所示:  故障分析: 一般来说,出现这种情况是因为电脑误删系统文件或者是系统文件被顽固木马破坏。       解决方法: 1、下载360安全卫士,找到里面的急救箱开始急救,然后进行修复,完成后重新启动; 2、下载瑞...

windows 7系统开机提示Windows驱动器未就绪的故障原因及解决方法

windows 7系统开机提示Windows驱动器未就绪的故障原因及解决方法

 故障分析: 主要原因应该是不存在软盘驱动器或驱动器未安装,找到故障原因后,Windows 7 32位系统只要将软盘驱动器禁用就可以了。 解决措施: 1、右键点击计算机,选择管理,打开计算机管理窗口; 2、在计算机管理中,找到设备管理器,在右边的软盘控制器中右击,选择卸载即可。 以...