首页 >数据库 >mysql教程 >如何使用左联接而不是存在或不在中删除SQL中的孤儿行?

如何使用左联接而不是存在或不在中删除SQL中的孤儿行?

Susan Sarandon
Susan Sarandon原创
2025-01-24 22:37:10433浏览

How to Delete Orphan Rows in SQL Using LEFT JOIN, NOT EXISTS, or NOT IN?

删除 SQL 表中没有匹配项的行

删除 SQL 表中的孤儿条目,一个常见的情况是识别表中在另一个表中缺少对应匹配的行。考虑以下情况:

您有两个表:

  • 表 files: 包含一个 id 列。
  • 表 blob: 包含一个 fileid 列。

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn