刪除 SQL 表中的孤兒條目,一個常見的情況是識別表中在另一個表中缺少對應匹配的行。考慮以下情況:
您有兩個表:
fileid 和 id 列可用於連接表。您的目標是刪除表 blob 中所有在表 files.id 中找不到 fileid 的行。
對於此任務,有三種主要方法:
使用 LEFT JOIN/IS NULL:
<code class="language-sql">DELETE b FROM BLOB b LEFT JOIN FILES f ON f.id = b.fileid WHERE f.id IS NULL</code>
使用 NOT EXISTS:
<code class="language-sql">DELETE FROM BLOB WHERE NOT EXISTS(SELECT NULL FROM FILES f WHERE f.id = fileid)</code>
使用 NOT IN:
<code class="language-sql">DELETE FROM BLOB WHERE fileid NOT IN (SELECT f.id FROM FILES f)</code>
警告:
執行 DELETE 操作時,務必確保它們在事務中執行。這允許您在發生任何錯誤時回滾更改,從而最大限度地降低數據丟失的風險。
以上是如何使用 LEFT JOIN、NOT EXISTS 或 NOT IN 刪除 SQL 中的孤立行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!