如何正確的使用一條SQL刪除重復(fù)數(shù)據(jù)
數(shù)據(jù)庫中表存在重復(fù)數(shù)據(jù),需要清理重復(fù)數(shù)據(jù),清理后保留其中一條的情況是比較常見的需求,如何通過1條SQL準(zhǔn)確的刪除數(shù)據(jù)呢?
1. 創(chuàng)建表及測試數(shù)據(jù)
1.1 數(shù)據(jù)庫中創(chuàng)建一張測試表
1.2 插入測試數(shù)據(jù)
1.3 查看重復(fù)數(shù)據(jù)
例如c1,c2 這2個(gè)字段組合作為唯一條件,則查詢重復(fù)數(shù)據(jù)的SQL如下
可見,結(jié)果如下:
2. 如何刪除重復(fù)數(shù)據(jù)
2.1 方案一
很多研發(fā)同學(xué)習(xí)慣的思路如下:
- 先查出重復(fù)的記錄(使用in)
- 再查出在重復(fù)記錄但id不在每組id最大值的記錄
- 直接將select 改為delete進(jìn)行刪除
查詢SQL如下
看上去比較符合結(jié)果了,但是改為delete執(zhí)行的時(shí)候結(jié)果如下:
出現(xiàn)報(bào)錯(cuò)信息:
也就是說MySQL里需刪除的目標(biāo)表在in子查詢中時(shí),不能直接執(zhí)行刪除操作。
3. 推薦寫法
基于以上情況,使用單條SQL刪除的方式如下:
查詢SQL:
刪除SQL
結(jié)果:
刪除后數(shù)據(jù)如下:
無重復(fù)數(shù)據(jù)了。