如何在 MySQL DELETE 语句中使用 LIMIT 删除一定范围的行?

Barbara Streisand
发布: 2024-10-28 04:41:02
原创
266 人浏览过

How to Delete a Range of Rows Using LIMIT in MySQL DELETE Statement?

使用 LIMIT 更正 MySQL DELETE 语句的语法

尝试使用以下 DELETE 语句从 MySQL 表中删除一系列行时LIMIT 子句,如果语法不正确,您可能会遇到错误。此错误通常表示用于指定限制的语法存在问题。

提供的查询中的问题是您无法在 DELETE 语句的 LIMIT 子句中指定偏移量。在 DELETE 语句中使用 LIMIT 子句的语法是 LIMIT ,不指定偏移量或起始点。

要解决此问题,您需要重写查询以指定要删除的行。删除得更准确。一种方法是使用 IN 子句选择要删除的行的 ID,然后使用这些 ID 来筛选 DELETE 语句中的行。

以下是如何重写的示例您的查询:

<code class="sql">DELETE FROM `chat_messages` 
WHERE `id` IN (
    SELECT `id` FROM (
        SELECT `id` FROM `chat_messages`
        ORDER BY `timestamp` DESC
        LIMIT 20, 50
    ) AS `x`
)</code>
登录后复制

在此查询中,我们首先使用子查询来选择要删除的行的 ID。然后,我们使用主 DELETE 语句中的 IN 子句根据这些 ID 过滤行,从而删除所需范围的行。

需要注意的是,您可能需要进行调整基于表的特定结构和所需行为的查询。

以上是如何在 MySQL DELETE 语句中使用 LIMIT 删除一定范围的行?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!