在SQL中刪除重復數據的方法有以下兩種方式:
WITH CTE AS (
SELECT *, ROW_NUMBER() OVER (PARTITION BY column1, column2 ORDER BY (SELECT NULL)) AS rn
FROM table_name
)
DELETE FROM CTE WHERE rn > 1;
上述代碼中,首先使用ROW_NUMBER()函數和OVER子句來為每行數據添加一個行號,然后根據指定的列(column1和column2)分組,將重復數據的行號標記為大于1的行,最后使用DELETE語句刪除這些重復數據。
DELETE FROM table_name a
WHERE EXISTS (
SELECT 1
FROM table_name b
WHERE a.column1 = b.column1
AND a.column2 = b.column2
AND a.primary_key > b.primary_key
);
上述代碼中,首先使用EXISTS子查詢來查找符合條件的重復數據,然后使用DELETE語句將這些重復數據刪除。需要注意的是,primary_key是表中的主鍵字段,用于區分不同的記錄。