场景:
假设我有两个表,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]
Run Code Online (Sandbox Code Playgroud)
或者我被迫这样做:
DELETE FROM TableA
WHERE
BId IN (SELECT BId FROM TableB WHERE [my filter condition])
Run Code Online (Sandbox Code Playgroud)
我问的原因是在我看来,在处理较大的表时,第一个选项会更有效.
谢谢!
我似乎永远不记得这个查询!
我想删除table1中的所有行,其ID与Table2中的相同.
所以:
DELETE table1 t1
WHERE t1.ID = t2.ID
Run Code Online (Sandbox Code Playgroud)
我知道我可以做一个WHERE ID IN(SELECT ID FROM table2)但是如果可能的话我想用JOIN做这个查询.