一个SQL Server数据库删除数据集中重复数据的例子

数据库 SQL Server
本文通过一个例子介绍了SQL Server数据库中删除数据集中的重复数据的操作过程,希望能够对您有所帮助。

SQL Server数据库操作中,有时对于表中的结果集,满足一定规则我们则认为是重复数据,而这些重复数据需要删除。如何删除呢?本文我们通过一个例子来加以说明。

例子如下:

如下只要companyName,invoiceNumber,customerNumber三者都相同,我们则认为是重复数据,下面的例子演示了如何删除。

 

  1. declare @InvoiceListMaster table ( ID int identity primary key ,    
  2.  
  3. companyName Nchar(20),    
  4.  
  5. invoiceNumber int,    
  6.  
  7. CustomerNumber int,    
  8.  
  9. rmaNumber int )    
  10.  
  11. insert    @InvoiceListMaster    
  12.  
  13. select N'华为', 1001,100,200    
  14.  
  15. union all    
  16.  
  17. select N'华为', 1001,100,300    
  18.  
  19. union all    
  20.  
  21. select N'华为', 1001,100,301    
  22.  
  23. union all    
  24.  
  25. select N'中兴', 1002, 200,1         
  26.  
  27. union all    
  28.  
  29. select N'中兴', 1002, 200,2    
  30.  
  31. select * from @InvoiceListMaster    
  32.  
  33. DELETE A    
  34.  
  35. from (    
  36.  
  37. select rown = ROW_NUMBER( )over( partition by companyname,    
  38.  
  39. invoicenumber,    
  40.  
  41. customerNumber     
  42.  
  43. order by companyname,    
  44.  
  45. invoicenumber,    
  46.  
  47. customerNumber ),    
  48.  
  49. companyname,    
  50.  
  51. invoicenumber,    
  52.  
  53. customerNumber    
  54.  
  55. from @InvoiceListMaster  )a    
  56.  
  57. where exists ( select 1     
  58.  
  59. from ( select rown = ROW_NUMBER( )over( partition by companyname,    
  60.  
  61. invoicenumber,    
  62.  
  63. customerNumber     
  64.  
  65. order by companyname,    
  66.  
  67. invoicenumber,    
  68.  
  69. customerNumber ),    
  70.  
  71. companyname,    
  72.  
  73. invoicenumber,    
  74.  
  75. customerNumber    
  76.  
  77. from @InvoiceListMaster  ) b    
  78.  
  79. where b.companyName = a.companyName    
  80.  
  81. and b.invoiceNumber = a.invoiceNumber    
  82.  
  83. and b.CustomerNumber = a.CustomerNumber    
  84.  
  85. and a.rown > b.rown    
  86.  
  87. )    
  88.  
  89. select * from @InvoiceListMaster 

 

以上的例子就演示了SQL Server数据库删除数据集中重复数据的过程,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. Oracle数据库账号频繁被锁定的原因排查
  2. Oracle数据库如何创建虚拟列和复合触发器
  3. MySQL数据库目录结构及常用命令的使用总结篇
  4. 利用C#对XML文档和数据库操作的四个技术节点
  5. 以MySQL为例介绍数据库测试工具dbmonster的使用
责任编辑:赵鹏 来源: CSDN博客
相关推荐

2011-05-24 10:54:15

数据库重复数据删除

2010-07-21 11:38:59

SQL Server重

2010-07-07 16:53:54

SQL Server重

2010-07-23 15:09:42

SQL Server删

2010-07-23 16:21:37

SQL Server重

2010-07-26 14:58:26

SQL Server删

2010-07-08 13:06:05

SQL Server删

2010-07-26 09:55:55

SQL Server重

2010-06-28 09:53:11

SQL Server数

2009-01-11 17:32:03

Oracle数据库重复数据

2011-03-14 15:47:33

Oracle数据库

2011-07-20 13:18:01

SQLite数据库修改和删除数据

2011-08-03 10:40:17

SQL Server数全文检索

2021-11-30 10:00:01

SQL数据重复

2010-07-01 12:29:27

SQL Server重

2010-04-08 16:28:07

Oracle数据库

2010-07-14 10:24:25

SQL Server获

2011-04-01 09:17:36

SQL Server数据库

2010-04-30 16:19:08

Oracle数据库

2011-08-15 11:24:46

SQL Server事务
点赞
收藏

51CTO技术栈公众号