使用 SQL 刪除沒有匹配項的行
在關係數據庫中處理多個表時,有時需要識別並刪除一個表中在另一個表中沒有對應匹配項的行。此過程通常稱為“刪除孤立條目”。
考慮以下場景:
為此,您可以使用各種 SQL 方法:
<code class="language-sql">DELETE b FROM BLOB b LEFT JOIN FILES f ON f.id = b.fileid WHERE f.id IS NULL</code>
<code class="language-sql">DELETE FROM BLOB WHERE NOT EXISTS(SELECT NULL FROM FILES f WHERE f.id = fileid)</code>
<code class="language-sql">DELETE FROM BLOB WHERE fileid NOT IN (SELECT f.id FROM FILES f)</code>
注意:如果可能,建議在事務中執行刪除操作,以便在出現任何意外問題時可以選擇回滾更改。
以上是如何使用 LEFT JOIN、EXISTS 或 NOT IN 子查詢刪除 SQL 中的孤立行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!