SQL中删除前1000条数据

DELETE   TABLENAME
WHERE   ID IN   (SELECT   TOP   1000   ID FROM   TABLENAME)

 

后续补充_____________________________________________

由于oracle和mysql中不支持"TOP"这个函数,所以需要根据情况调整,但原理都是相同的

oracle

Oracle 不支持 TOP 关键字:不过这个好像并不十分严重,因为它提供了 rownum 这个隐式游标,可以实现与 TOP 类似的功能,如:

SELECT TOP 10 ... FROM WHERE ...
要写成

SELECT ... FROM ... WHERE ... AND rownum <= 10
rownum 是记录序号(1,2,3...),但有一个比较麻烦的事情是:如果 SQL 语句中有 ORDER BY ... 排序的时候,rownum 居然是先“标号”后排序!这样,这个序号如果不加处理是不合乎使用需求的。

至于临时表,Oracle 的临时表和 SQL Server 的有很大不同。

根据这篇文章的介绍,可以如下分页:

SELECT * FROM
      (
      SELECT A.*, rownum r
      FROM
           (
           SELECT *
           FROM Articles
           ORDER BY PubTime DESC

           ) A
      WHERE rownum <= PageUpperBound
      ) B
WHERE r > PageLowerBound;
其中蓝色部分可以改为任意的、需要的 SQL SELECT 语句,这点倒是挺方便的。
 

mysql:

order by id desc limit 0,10 按照id的倒序排序 取出前10条
order by id limit 5,10 按照id的正序排序 从第5条开始取10条

 

只需要将

DELETE   TABLENAME
WHERE   ID IN   (SELECT   TOP   1000   ID FROM   TABLENAME)

中的红色部分替换即可


版权声明:本文为Eric_splendid原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。