首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在同一查询中从表A和表B(如果存在)中删除?

如何在同一查询中从表A和表B(如果存在)中删除?
EN

Stack Overflow用户
提问于 2021-01-14 10:36:53
回答 2查看 40关注 0票数 0

我在下面尝试过,但没有成功,因为table_B是空的,所以失败了。因此,即使table_B为空,我也希望至少从table_A中删除该记录。

仅供参考: table_A记录始终存在,因此如果该记录存在,则无需搜索。

代码语言:javascript
运行
复制
$sql_remove_rfid = $dbi->prepare("
DELETE 
  FROM table_A
     , table_B
  LEFT 
  JOIN table_B 
    ON table_A.id = table_B.key
WHERE table_A.id=?");
EN

Stack Overflow用户

发布于 2021-01-14 10:49:47

你的语法不太正确,应该是:

代码语言:javascript
运行
复制
DELETE A, B
FROM table_A A
LEFT JOIN table_B B ON A.id = B.key
WHERE A.id=?

请注意,一般来说,最好避免使用MySQL保留字(key)作为列名。

另请注意,如果key是从table_Btable_A的外键,并且您总是希望在删除table_B中的相应id时从table_A中删除条目,则可以将key定义为table_A(id)的外键并指定ON DELETE CASCADE

代码语言:javascript
运行
复制
ALTER TABLE table_B ADD FOREIGN KEY (`key`) REFERENCES table_A(id) ON DELETE CASCADE

然后,您可以简单地从table_A中删除,table_B中的相应行(如果有)将自动删除:

代码语言:javascript
运行
复制
DELETE
FROM table_A
WHERE id = ?
票数 2
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65712621

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档