首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从表中删除Top-N‘行,并进行排序(按’Column‘排序)

从表中删除Top-N‘行,并进行排序(按’Column‘排序)
EN

Stack Overflow用户
提问于 2012-11-22 16:09:21
回答 2查看 33.8K关注 0票数 40

我对删除按某列排序的前N行有些困惑。

我在这里创建了一个Example at fiddle示例

这些查询有什么问题?

代码语言:javascript
复制
 Delete Top(3) from Table1 order by id desc

 Delete Top(3) from Table1 
 where id IN (select id from Table1 order by id desc)

因为在mysql中,limit关键字可以很好地完成这项工作

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-11-22 16:11:22

您可以使用CTE执行faster ordered delete,而不需要单独的子查询来检索前3个ids。

代码语言:javascript
复制
WITH T
     AS (SELECT TOP 3 *
         FROM   Table1
         ORDER  BY id DESC)
DELETE FROM T 
票数 85
EN

Stack Overflow用户

发布于 2012-11-22 16:10:32

top 3子句添加到子选择中:

代码语言:javascript
复制
Delete from Table1 
where id IN (
    select top 3 id 
    from Table1 
    order by id desc
)
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13508280

复制
相关文章

相似问题

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