如何正確的使用一條SQL刪除重復數據
作者:數據庫干貨鋪
數據庫中表存在重復數據,需要清理重復數據,清理后保留其中一條的情況是比較常見的需求,如何通過1條SQL準確的刪除數據呢?
數據庫中表存在重復數據,需要清理重復數據,清理后保留其中一條的情況是比較常見的需求,如何通過1條SQL準確的刪除數據呢?
1. 創建表及測試數據
1.1 數據庫中創建一張測試表
1.2 插入測試數據
1.3 查看重復數據
例如c1,c2 這2個字段組合作為唯一條件,則查詢重復數據的SQL如下
可見,結果如下:
2. 如何刪除重復數據
2.1 方案一
很多研發同學習慣的思路如下:
- 先查出重復的記錄(使用in)
- 再查出在重復記錄但id不在每組id最大值的記錄
- 直接將select 改為delete進行刪除
查詢SQL如下
看上去比較符合結果了,但是改為delete執行的時候結果如下:
出現報錯信息:
也就是說MySQL里需刪除的目標表在in子查詢中時,不能直接執行刪除操作。
3. 推薦寫法
基于以上情況,使用單條SQL刪除的方式如下:
查詢SQL:
刪除SQL
結果:
刪除后數據如下:
無重復數據了。
責任編輯:華軒
來源:
今日頭條