首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySql 8 delete with查询with limit

MySql 8 delete with查询with limit
EN

Stack Overflow用户
提问于 2020-03-27 18:56:21
回答 2查看 203关注 0票数 0

我对这个查询有一个问题:

代码语言:javascript
复制
DELETE FROM tableA
WHERE idTableA IN
(SELECT tA.idTableA
    FROM tableB tB
    LEFT JOIN tableA tA ON tB.idTableB = tA.idTableA
    WHERE tB.campoX = 100 LIMIT 1);

错误响应:错误码: 1235。此版本的MySQL尚不支持'LIMIT &IN/ALL/ANY/SOUN子查询‘

示例数据:

TableB 10行(它是一个表主文件)

TableA 50行(这是tableB的明细表)

我想删除tableA的所有与master ( tableB )相关的记录详细信息,在tableB上使用条件过滤器,限制为1行(此限制仅用于测量一个delete行的执行时间)

MySql版本:8

有什么想法吗?tk

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-03-27 19:03:03

代码语言:javascript
复制
DELETE tableA.*
FROM tableA 
JOIN (SELECT tA.idTableA
      FROM tableB tB
      LEFT JOIN tableA tA ON tB.idTableB = tA.idTableA
      WHERE tB.campoX = 100 LIMIT 1) USING (idTableA);
票数 0
EN

Stack Overflow用户

发布于 2020-03-27 19:18:51

您可以使用exists来选择行(这最好处理b中有多行匹配的情况),并在外部查询中直接使用limit

代码语言:javascript
复制
delete from tablea a
where exists (select 1 from tableb b where b.campox = 100 and b.idtableb = a.itablea)
order by a.idtablea
limit 1

请注意,我在查询中添加了一个order by子句,因此可以清楚地定义要删除的记录。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60884599

复制
相关文章

相似问题

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