首頁 > 資料庫 > mysql教程 > 如何在保留一筆記錄的同時有效率地刪除MySQL中的重複行?

如何在保留一筆記錄的同時有效率地刪除MySQL中的重複行?

Barbara Streisand
發布: 2025-01-23 13:21:10
原創
580 人瀏覽過

How to Efficiently Delete Duplicate Rows in MySQL While Keeping One Record?

MySQL中刪除重複行(重複資料)

問題:

如何從MySQL表中刪除重複行,同時保留每個唯一值的單一記錄?

範例:

考慮names表中的以下資料:

id name
1 google
2 yahoo
3 msn
4 google
5 google
6 yahoo

解:

警告:務必採取預防措施,首先在表格的測試副本上執行此操作。

要刪除所有重複行(保留一個),並保留具有最低或最高id值的記錄,請使用以下查詢:

保留最低id值:

<code class="language-sql">DELETE n1 FROM names n1, names n2 WHERE n1.id > n2.id AND n1.name = n2.name</code>
登入後複製

保留最高id值:

<code class="language-sql">DELETE n1 FROM names n1, names n2 WHERE n1.id < n2.id AND n1.name = n2.name</code>
登入後複製

附加說明:

  • 確保在兩個查詢中都新增條件AND n1.id != n2.id,以防止意外刪除所有行。
  • 此方法計算成本很高,如果表很大,可能會中斷您的連線。
  • 對於大型表,請考慮使用DISTINCT的INSERT作為更快的替代方法:
<code class="language-sql">INSERT INTO tempTableName(cellId,attributeId,entityRowId,value)
    SELECT DISTINCT cellId,attributeId,entityRowId,value
    FROM tableName;</code>
登入後複製

以上是如何在保留一筆記錄的同時有效率地刪除MySQL中的重複行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板