开发者社区 问答 正文

如何在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

问题来源于stack overflow

展开
收起
保持可爱mmm 2019-11-15 15:45:11 541 分享 版权
1 条回答
写回答
取消 提交回答
  • 您可以使用以下一种:

    SELECT * FROM ( SELECT ROW_NUMBER() OVER (ORDER BY key ASC) AS rownumber, columns FROM tablename ) AS foo WHERE rownumber <= n

    2019-11-15 15:45:24
    赞同 展开评论