使用SQL查询删除除最新N条记录外的所有记录
在MySQL中,可以删除表中除按降序ID排序的最新N条记录外的所有记录。这可以使用单个MySQL查询来实现,尽管不像预期的那样简单直接。
简单的使用类似这样的查询:
<code class="language-sql">delete from table order by id ASC limit ((select count(*) from table ) - N)</code>
将会失败,因为无法使用子查询来指定LIMIT子句的值。要实现此目的,需要更复杂的查询:
<code class="language-sql">DELETE FROM `table` WHERE id NOT IN ( SELECT id FROM ( SELECT id FROM `table` ORDER BY id DESC LIMIT N ) foo );</code>
在这个查询中,使用中间子查询来选择最新N条记录的ID。然后,主查询使用此子查询在一个NOT IN运算符中,将这些记录从删除过程中排除。这种方法允许我们绕过直接在LIMIT子句中或主查询的FROM子句中使用子查询的限制。
值得注意的是,中间子查询是必不可少的。如果没有它,我们会遇到与在子查询中引用正在删除的表以及早期版本的MySQL强加的限制相关的错误,这些限制不支持在NOT IN运算符中使用的子查询中使用LIMIT子句。
通过使用此查询,可以有效地删除表中除按特定列排序的最新N条记录外的所有记录,确保保留最新数据。
以上是如何使用单个查询删除 MySQL 中除最新 N 条记录之外的所有记录?的详细内容。更多信息请关注PHP中文网其他相关文章!