小编典典

T-SQL:通过连接选择要删除的行

all

设想:

假设我有两个表,TableA 和 TableB。TableB 的主键是单列(BId),是TableA 中的外键列。

在我的情况下,我想删除 TableA 中与 TableB 中特定行链接的所有行:我可以通过联接来做到这一点吗?删除从联接中拉入的所有行?

DELETE FROM TableA 
FROM
   TableA a
   INNER JOIN TableB b
      ON b.BId = a.BId
      AND [my filter condition]

还是我被迫这样做:

DELETE FROM TableA
WHERE
   BId IN (SELECT BId FROM TableB WHERE [my filter condition])

我问的原因是,在我看来,第一个选项在处理更大的表时会更有效。

谢谢!


阅读 89

收藏
2022-03-11

共1个答案

小编典典

DELETE TableA
FROM   TableA a
       INNER JOIN TableB b
               ON b.Bid = a.Bid
                  AND [my filter condition]

应该管用

2022-03-11