基於不符ID刪除孤兒行
問題:
從blob
表中刪除fileid
在files
表中找不到符合id
的行。
表格結構:
<code>files表: | id | .... | |---|---| | 1 | .... | | 2 | .... | | 7 | .... | | 9 | .... | blob表: | fileid | .... | |---|---| | 1 | .... | | 2 | .... | | 3 | .... | | 4 | .... | | 4 | .... | | 4 | .... | | 9 | .... |</code>
預期結果:
刪除blob
表中fileid
為3和4的行,因為它們在files
表中沒有匹配的fileid
。
解:
1. 使用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>
2. 使用NOT EXISTS:
<code class="language-sql">DELETE FROM BLOB WHERE NOT EXISTS(SELECT NULL FROM FILES f WHERE f.id = fileid)</code>
3. 使用NOT IN:
<code class="language-sql">DELETE FROM BLOB WHERE fileid NOT IN (SELECT f.id FROM FILES f)</code>
警告:
為確保在發生錯誤時可以回滾,請在交易中執行DELETE操作。
以上是如何根據無與倫比的ID刪除數據庫表中的孤兒行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!