记录mssql如何有效消除重复记录(mssql 消除二个重复)

用MSSQL消除重复记录是一个经常要面对的疑难问题。通过有效的手段,能效率高的去除重复记录,会大大提高工作效率,并减少不必要的时间浪费。

一、删除重复记录中的填充重复记录

MSSQL有一种特殊的方法,就是删除重复记录中的填充重复记录,可以很有效的消除重复记录。可以使用代码如下:

“`sql

DELETE FROM TEMP

WHERE ROW_NUMBER() OVER(PARTITION BY 字段名 ORDER BY 字段名) >1


1)填充删除重复记录命令,可以指定按照那些字段分组,可以针对具体表中的重复记录进行删除,非常有效。

例如,假设有一个表tbProduct,其中存在重复记录。要消除重复记录,可以使用如下语句:

```sql
DELETE FROM TbProduct
WHERE ROW_NUMBER() OVER(PARTITION BY ProductID ORDER BY ProductID) > 1

2)消除重复记录提示,可以选择某个表中的记录,根据某个[字段]进行统计,因为统计结果显示重复,本语句可以有效消除重复记录。

例如,假设有一个表tbProduct,其中存在重复记录。要查找重复记录,可以使用如下语句:

“`sql

SELECT ProductName COUNT(*),COUNT(distinct ProductName)

FROM TbProduct

GROUP BY ProductName

HAVING COUNT(*) > 1


二、删除重复记录中的指定重复记录

1)删除重复记录中的指定重复记录,可以通过使用CTE(Common Table Expression)语句,来实现对重复记录的消除。这种方法让你可以定位指定的重复记录,而不影响其它的不重复记录。

需要将SELECT语句和DELETE语句结合起来,以及创建一个变量来标记被删除的记录。

例如,假设有一个表tbProduct,其中存在重复记录,要指定删除重复记录,可以使用如下语句:

```sql
WITH CTE AS
(SELECT ROW_NUMBER() OVER(PARTITION BY ProductName ORDER BY ProductID) AS RN,ProductID
FROM TbProduct
)
UPDATE CTE
SET RN = RN +10 ;
DELETE FROM CTE
WHERE RN > 11

2)消除重复记录提示,可以使用游标遍历表中的每一条记录,同时记录下重复的记录,然后将这些记录从表中删除。但这种方法性能低,耗时慢,不推荐使用。

最后,MSSQL消除重复记录有多种方法可供选择,可以根据需要选择最有效的方式来实现。


数据运维技术 » 记录mssql如何有效消除重复记录(mssql 消除二个重复)