开发者社区 问答 正文

如何在SQL数据库表中选择第n行?

我有兴趣学习一些(理想情况下)从数据库表中选择第n行的数据库不可知方法。看看如何使用以下数据库的本机功能实现此目标也将很有趣:

SQL服务器 的MySQL PostgreSQL的 SQLite的 甲骨文 我目前在SQL Server 2005中执行类似以下的操作,但是我希望看到其他人的不可知论方法:

WITH Ordered AS ( SELECT ROW_NUMBER() OVER (ORDER BY OrderID) AS RowNumber, OrderID, OrderDate FROM Orders) SELECT * FROM Ordered WHERE RowNumber = 1000000

展开
收起
保持可爱mmm 2020-05-10 18:53:03 649 分享 版权
1 条回答
写回答
取消 提交回答
  • 在标准的可选部分中有执行此操作的方法,但是许多数据库都支持其自己的执行方法。

    http://troels.arvin.dk/db/rdbms/#select-limit是一个非常好的网站,可以讨论此问题和其他问题。

    基本上,PostgreSQL和MySQL支持非标准的:

    SELECT... LIMIT y OFFSET x Oracle,DB2和MSSQL支持标准的窗口功能:

    SELECT * FROM ( SELECT ROW_NUMBER() OVER (ORDER BY key ASC) AS rownumber, columns FROM tablename ) AS foo WHERE rownumber <= n (由于我从未使用过这些数据库,所以我只是从上面链接的站点复制了该文件)

    更新:从PostgreSQL 8.4开始,支持标准的窗口功能,因此希望第二个示例也适用于PostgreSQL。

    更新: SQLite在2018-09-15的3.25.0版本中添加了窗口功能支持,因此两种形式都可以在SQLite中使用。

    2020-05-10 18:53:17
    赞同 展开评论