0 0

oracle rownum oderby错误0

1 select a.p,a.s from (select * from aa r order by r.s) a  where ROWNUM  < 10;
2 select a.p,a.s from (select * from aa r order by r.s) a  where ROWNUM  < 20;

我想实现语句2的结果的前10条数据是1查出来的数据,但是这样写是错误的,为什么?
2013年2月26日 16:41

1个答案 按时间排序 按投票排序

0 0

select a.p , a.s (select r.p , r.s , row_number() over (order by r.s) as rown from aa r) a where rown < 10;
select a.p , a.s (select r.p , r.s , row_number() over (order by r.s) as rown from aa r) a where rown < 20;

2013年2月26日 17:21

相关推荐

    oracle rownum 的使用 和sqlserver有区别的!

    - Oracle 中的 ROWNUM 不受 ORDER BY 影响,即无论是否使用 ORDER BY 子句,ROWNUM 都是从 1 开始计数的。 - 而在 SQL Server 中,如果需要按特定顺序为行分配行号,则必须使用 ORDER BY 与 ROW_NUMBER() 结合的...

    oracle rownum 学习

    SELECT ROWNUM, ID, NAME FROM STUDENT ORDER BY NAME; ``` 可以看出,ROWNUM并不是按照NAME列来生成的序号。系统是按照记录插入时的顺序给记录排的号,ROWID也是顺序分配的。为了解决这个问题,必须使用子查询。 ...

    ORACLE 中ROWNUM用法总结

    SELECT * FROM table ORDER BY some_column ) t WHERE ROWNUM ) WHERE rnum &gt; 10; ``` #### 误区2:`BETWEEN`操作符的使用 同样地,`BETWEEN`操作符在`ROWNUM`的使用上也有局限性。例如,`ROWNUM BETWEEN 1 AND...

    ROWNUM的使用技巧

    order by a.column_name ) a ) b where b.rn ; ``` 这将返回结果中的前 5 条记录,并且正确地排序和取值。 其他实现方式 另外一种实现方式是使用 ROWNUM 和 MINUS 操作符结合来实现分页查询。例如: ```...

    Oracle rownum.docx

    解决这个问题的方法是将ROWNUM和ORDER BY一起放入子查询,如`SELECT ROWNUM, id, name FROM (SELECT * FROM student ORDER BY name)`,这样ROWNUM将会按照name列的排序生成。 总的来说,理解并掌握Oracle中的ROWNUM...

    oracle rownum 使用技术.pdf

    2. **ORDER BY与ROWNUM的交互**:如果需要先排序再限制结果数量,最好使用子查询的方法,确保排序后的数据被正确计数。 3. **性能考虑**:在处理大量数据时,应考虑使用其他方法如窗口函数(如RANK()、ROW_NUMBER()...

    Oracle数据库中ORDER BY排序和查询按IN条件的顺序输出

    本文将深入探讨`ORDER BY`子句在Oracle中的排序机制,以及查询时根据`IN`条件顺序输出的方法。 首先,`ORDER BY`用于指定查询结果的排序方式,可以基于一个或多个列进行升序(ASC)或降序(DESC)排序。然而,...

    oracle-rownum用法

    SELECT ROWNUM, id, name FROM student ORDER BY name; ``` 可以看出,ROWNUM 并不是按照 name 列来生成的序号。系统是按照记录插入时的顺序给记录排的号,ROWID 也是顺序分配的。为了解决这个问题,必须使用子查询...

    oracle的rownum用法

    这意味着如果没有`ORDER BY`子句,`ROWNUM`的顺序可能是不确定的,因为Oracle数据库可能按照任意顺序读取数据。如果使用`ORDER BY`,`ROWNUM`将根据指定的排序规则进行分配。 在使用`ROWNUM`进行条件过滤时,需要...

    oracle中rownum的用法及解说

    - 为了确保`ROWNUM`的值与`ORDER BY`的结果一致,应先进行排序,再计算`ROWNUM`。 - **示例**: ```sql SELECT * FROM (SELECT ROWNUM NO, ID, NAME FROM (SELECT * FROM STUDENT ORDER BY NAME)) WHERE NO ; `...

    mysql类似oracle rownum写法实例详解

    SELECT * FROM t WHERE ROWNUM = 1 ORDER BY id; ``` 而在 MySQL 中,要达到相同的效果,你需要使用 `LIMIT` 关键字配合 `ORDER BY`,如下所示: ```sql SELECT * FROM t ORDER BY id LIMIT 1; ``` 对于批量插入...

    oracle中rownum的用法

    SELECT * FROM (SELECT * FROM TABLE_NAME ORDER BY COLUMN) WHERE ROWNUM ; ``` 这种方法通过先排序后应用`ROWNUM`的方式,能够更高效地检索数据。 ##### 2. 获取特定范围内的数据 如果您想要获取某个特定范围内的...

    Oracle利用rownum查询出部分数据[归类].pdf

    总结一下,`ROWNUM`在Oracle中用于限制查询返回的行数,但它的行为并不直观,特别是在与`ORDER BY`一起使用时。理解`ROWNUM`的生成原理以及其与`ORDER BY`的交互对于优化SQL查询和获取预期结果至关重要。在实际的...

    Oracle--ROWNUM.rar_oracle

    需要注意的是,`ROWNUM`的筛选是在数据读取过程中进行的,而非对整个数据集进行排序后筛选,所以如果你没有指定`ORDER BY`子句,返回的结果顺序可能是不确定的。 在进行分页查询时,`ROWNUM`结合`ROWCOUNT`或者`...

    在oracle中灵活使用Rownum和rowId

    SELECT ROWNUM, MONTH, SELL FROM SALE ORDER BY MONTH WHERE ROWNUM ; ``` 这样返回的结果将会按照月份从小到大排序: ```plaintext ROWNUM MONTH SELL ------------------------ 1 200001 1000 2 200002 1100 3 ...

    oracle_SQL-rowid--rownum.zip_oracle

    需要注意的是,`ROWNUM`是在查询执行过程中动态生成的,并且在`ORDER BY`子句之前被计算。这意味着,如果不配合`ORDER BY`,`ROWNUM`的值可能不是预期的顺序。 **ROWID与ROWNUM的区别** - `ROWID`是物理地址,而`...

    oracle_SQL中rowid与rownum的使用

    2. **优化查询**:与`ORDER BY`一起使用时,先筛选`ROWNUM`再排序可以提高效率,避免全表排序。 3. **联合查询**:在多个表的连接查询中,通过`ROWNUM`过滤结果可以减少不必要的数据处理。 五、ROWID应用示例 `...

    解决Oracle分页查询中排序与效率问题

    在Oracle中实现分页查询通常有两种方法:基于ROWNUM的方法和子查询方法。这里主要讨论的是基于ROWNUM的分页查询方式。其基本思想是通过ROWNUM过滤出特定范围内的记录,然后返回这些记录。 #### 二、原始SQL查询分析...

    oracle的分页查询

    Oracle 的分页查询 ...Oracle 中的分页查询可以使用 ROWNUM 伪列和 ORDER BY 子句来实现,但是需要注意 ROWNUP 伪列的生成机制和 ORDER BY 子句的影响。同时,我们也可以使用 ROWID 列来实现真正的分页查询。

Global site tag (gtag.js) - Google Analytics