开发者社区> 问答> 正文

为什么这条sql分页无效?

screenshot
DB结构
id number类型
name varchar2类型

展开
收起
吴孟桥 2016-06-17 10:29:52 1974 0
1 条回答
写回答
取消 提交回答
  • [1] rownum不支持以下方式的查询
    a: select * from area where rownum > 2;
    b: select * from area where rownum = n; --where n is a integer number lager than 1
    注:rownum只支持select * from area where rownum =1的查询。Oracle的官方文档说明如下:
    Conditions testing for ROWNUM values greater than a positive integer are always false.
    For example, this query returns no rows:
    SELECT * FROM employees
    WHERE ROWNUM > 1;
    The first row fetched is assigned a ROWNUM of 1 and makes the condition false. The
    second row to be fetched is now the first row and is also assigned a ROWNUM of 1 and
    makes the condition false. All rows subsequently fail to satisfy the condition, so no
    rows are returned.
    因为rownum是根据查询的结果集来对记录进行编号,所以当你查询rownum大于2的记录时会得到一个空的结果集。因为当oracle查询得到第1条记录时,发现rownum为1不满足条件,然后就继续查询第2条记录,但此时第2条记录又被编号为1(也即rownum变为1),所以查询得到的始终是rownum=1,因此无法满足约束,最终查询的结果集为空。

    2019-07-17 19:42:07
    赞同 展开评论 打赏
问答分类:
SQL
问答标签:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
SQL Server在电子商务中的应用与实践 立即下载
GeoMesa on Spark SQL 立即下载
原生SQL on Hadoop引擎- Apache HAWQ 2.x最新技术解密malili 立即下载