当前位置:  开发笔记 > 后端 > 正文

删除50个最新行以外的所有行

如何解决《删除50个最新行以外的所有行》经验,为你挑选了2个好方法。

我有一个包含新闻故事和Unix时间戳的SQL表.我只想保留50个最新的故事.如何编写SQL语句来删除任何数量的旧故事?



1> Davide Vosti..:

大段引用

delete from table where id not in (
    select id from table 
    order by id desc 
    limit 50
)

您选择了不想删除的数据的ID,并删除了这些值中的所有内容...



2> Gilean..:

我最终使用了两个查询,因为MySQL5还没有在子查询中支持LIMIT

SELECT unixTime FROM entries ORDER BY unixTime DESC LIMIT 49, 1;
DELETE FROM entries WHERE unixTime < $sqlResult;

推荐阅读
Gbom2402851125
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有