相关疑难解决方法(0)

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

场景:

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

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

谢谢!

t-sql join

486
推荐指数
5
解决办法
39万
查看次数

如何在使用JOIN时在MS Access中删除?

我试图DELETE在MS Access中使用该子句,并在使用该JOIN子句时遇到问题.我注意到这可以通过使用DISTINCTROW关键字来完成.

例如,以下SQL语句不允许删除:

DELETE Table1.*
FROM Table1 INNER JOIN Table2 ON Table1.Name=Table2.Name;
Run Code Online (Sandbox Code Playgroud)

但是,这句话的确如下:

DELETE DISTINCTROW Table1.*
FROM Table1 INNER JOIN Table2 ON Table1.Name=Table2.Name;
Run Code Online (Sandbox Code Playgroud)
  • DELETE使用DISTINCTROW关键词时为什么要工作?
  • 更具体地说,JET引擎中发生了什么需要这个?

sql ms-access delete-row sql-delete

24
推荐指数
1
解决办法
7万
查看次数

标签 统计

delete-row ×1

join ×1

ms-access ×1

sql ×1

sql-delete ×1

t-sql ×1