场景:

假设我有两个表,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])

我问这个问题的原因是,在处理较大的表时,第一种选择似乎更有效。

谢谢!


当前回答

假设您有2个表,其中一个具有Master集(例如。员工)和一个有孩子的集合(例如。Dependents),您希望摆脱Dependents表中所有不能与Master表中的任何行进行键合的数据行。

delete from Dependents where EmpID in (
select d.EmpID from Employees e 
    right join Dependents d on e.EmpID = d.EmpID
    where e.EmpID is null)

这里需要注意的一点是,您只是首先从连接中收集了一个empid“数组”,使用该empid集在dependencies表上执行删除操作。

其他回答

试图用访问数据库做到这一点,发现我需要在删除后使用一个。*。

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

应该工作

这在MySQL中几乎是一样的,但是你必须在单词“DELETE”后面使用表别名:

DELETE a
FROM TableA AS a
INNER JOIN TableB AS b
ON a.BId = b.BId
WHERE [filter condition]
DELETE FROM table1
where id IN 
    (SELECT id FROM table2..INNER JOIN..INNER JOIN WHERE etc)

尽量减少使用连接的DML查询。您应该能够使用上面的子查询执行大部分DML查询。

一般来说,只有在需要在两个或多个表中按列进行SELECT或GROUP时才应该使用连接。如果您只使用多个表来定义一个填充,请使用子查询。对于DELETE查询,使用相关子查询。

是的,你可以。例子:

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