mysql 重複資料刪除資料

來源:互聯網
上載者:User

標籤: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 重複資料刪除資料

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.