標籤:sql
如題:mysql 資料庫重複資料刪除資料
因為是mysql 所以其他資料哭的命令在mysql 中是不能使用的。不要想當然的使用sql 指令碼
delete from table1where field1 in (select field1 from table1 group by field1 having count(field1) > 1) and rowid not in (select min(rowid) from table1 group by field1 having count(field1)>1)
這是 oracle 資料庫的命令。mysql 用會報錯。
you can’t specify target table ‘table1’ for update in from clause 錯誤。
因為 mysql 裡 沒有 rowid 而且 mysql 中規定 不能在同一個表進行 選擇 和 更新,刪除等操作。
所以問題來了,怎麼來進行重複資料刪除的資料呢?
-
現在重複有兩種情況:
-
1、整體的重複:比如沒有主鍵的話,可能會出現,行與行是完全一樣的。
這種的話可以藉助輔助暫存資料表來實現。
就可以使用 sql 語句:
CREATE TABLE temp SELECT DISTINCT * FROM table1 ;
然後刪除原表 在進行手動修改表名……
也可直接使用 sql指令碼:
CREATE TABLE temp SELECT DISTINCT * FROM table1 ;DELETE FROM table1 ;INSERT INTO table1 SELECT * FROM temp;DROP TABLE temp;
-
2、只是幾個關鍵字段的值是重複的,可能是插入或者更新的時候,操作重複了造成的。
前面講過了 mysql 不能同時對一張表進行插入 和 更新等操作,所以我們要換條路。
我的方法是 使用暫存資料表來進行間接操作。
CREATE TABLE tmp AS SELECT MIN(ID) AS col FROM test GROUP BY RID; DELETE FROM test WHERE ID NOT IN (SELECT col FROM tmp); DROP TABLE tmp;
PS:這裡 RID 是重複的欄位(之一)。保留的是 ID 最小的一行資料。刪除其他重複的行。
可能還有方法,這隻是我現在找到的方法,如果有什麼新方法的話,可以來添加哦。
mysql 重複資料刪除資料