oracle伪列ROWNUMBER,Oracle伪列(ROWNUM)的使用

先看一个题:查询emp表的信息,显示前5行数据,这时候我们就需要使用伪列(rownum)的概念。

rownum在数据表并不是一个真实的列,其实每一行应该都有一个行号,这个伪列就是用来记录这个行号的,这个列可以进行一些操作,比如取等于和小于操作,不能取大于操作。

*****查询emp表的信息,显示前5行数据*****

SELECT * FROM emp WHERE rownum <= 5 ;

如果我们要查询第5-10行数据,这时候该怎么办?就需要使用到子查询。

SELECT * FROM ( SELECT rownum r,emp.* FROM emp ) a

WHERE a.r between 5 and 10

*****查询emp表中的员工信息,只显示后面一半的员工信息*****

SELECT * FROM ( SELECT rownum r,emp.* FROM emp ) a

WHERE a.r <=(SELECT COUNT(empno) FROM emp) ;

在Oracle中,除了有伪列的概念,还有伪表的概念。比如,要查询当前的日期是什么,我们知道函数是SYSDATE,而SQL语句需要使用SELECT sysdate从SQL语法的角度是不完整的,所以需要使用伪表tab,完整语句为:SELECT sysdate FROM tab,例如:SELECT dbms_random.value(0,1) FROM dual,也是使用了伪表(dual)。

Oracle伪列(ROWNUM)的使用

标签:bms   row   tween   概念   dom   函数   查询   rom   需要

1428d0e076c3959ab11d28a39bc84fab.png

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:http://www.cnblogs.com/laoluoits/p/6786373.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 1. rownumber:是Oracle数据库中的一个伪列,用于给查询结果集中的每一行分配一个唯一的序号。这个序号是在查询结果集返回之前就已经分配好的,不受查询条件的影响。可以通过在查询语句中使用ROWNUM关键字来访问这个伪列。 2. rowid:是Oracle数据库中的一个特殊列,用于唯一标识表中的每一行。每一行都有一个唯一的rowid值,可以通过查询语句中的ROWID伪列来访问它。rowid值是由Oracle数据库自动生成的,它包含了表空间、数据文件、数据块和行号等信息,可以用于快速定位表中的某一行。 ### 回答2: Oracle中的ROWNUMROWID是两个不同的概念。 ROWNUM是一个伪列,用于对结果集中的行进行编号。每个查询语句都有一个带有ROWNUM列的结果集。这个ROWNUM是在查询结果返回之后进行计算的,所以它不会按照行在表中的顺序进行排序。对于查询结果集中的每一行,ROWNUM都会自动分配一个唯一的编号,从1开始递增。可以将ROWNUM与ORDER BY语句配合使用,以确保结果集中的行按照数据库中的顺序进行排序。 ROWID是一个物理地址,用于唯一标识表中的行。每一行都有一个唯一的ROWID,表示用于查找这一行的物理存储位置。ROWID可以用作空间和时间优化的基础,因为它可以避免对整个表进行逐行扫描。ROWID列通常被用于数据表的分片。 总之,ROWNUM用于对结果集中的行进行编号,而ROWID用于标识表中的行。它们都有很多用途和应用场景,但它们的作用和含义是不同的。 ### 回答3: Oracle中的rownumrowid是两种非常重要的概念,这两个概念的作用不同,但同样对于数据库的查询优化和开发具有重要的意义。 首先,我们来看看rownum。在Oracle中,rownum是一个伪列,唯一的作用是为结果集中的每一行都分配一个唯一的数字ID。它可以用于限制结果集大小、排序和分页等操作。在查询结果集前20行的情况下,rownum可以写成: Select emp_name, emp_id From employee Where rownum <= 20; 这将返回前20行结果。需要注意的是,rownum用于过滤记录前,必须使用子查询,否则无法达到需求。 rowid则是物理地址,每一行记录在物理上都占有一个rowid,通过检索rowid可以直接访问表中的记录,避免了全表扫描。在Oracle中,rowid是唯一的,而且只有当表进行操作时,如更新或删除一行数据,才会随之更新。在查询语句中,可以用rowid直接查找一个特定的记录,如: Select emp_name, emp_id From employee Where rowid = 'AAAACcAAHAAAAJfAAA'; 它会返回rowid为'AAAACcAAHAAAAJfAAA'的记录的emp_name和emp_id两列的值。 总结来说,rownumrowid的作用不同,前者用于分页、排序、结果集过滤等操作,而后者用于直接检索并操作单条记录。在通过这两个概念进行优化查询时,应根据不同的需求选择使用

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值