删除 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 操作时,务必确保它们在事务中执行。这允许您在发生任何错误时回滚更改,从而最大限度地降低数据丢失的风险。
以上是如何使用左联接而不是存在或不在中删除SQL中的孤儿行?的详细内容。更多信息请关注PHP中文网其他相关文章!