1.概念
rowid和rownum都是伪列(实际上这一列本身在数据字典中并不存在,在查询结果输出时它被构造出来的);
1)rownum是基于查询结果的顺序标记,而且是逐次递加的,换句话说就是只要有rownum=1的记录,才可能有rownum=2的记录
2)rowid是用于定位数据库中一条记录的一个相对唯一地址值。通常情况下,该值在该行数据插入到数据库表时即被确定且唯一。而对于聚簇表,由于聚簇特性,不同表上的记录由于存储在相同的簇上,因此会拥有相同的ROWID。数据库的大多数操作都是通过ROWID来完成的,而且使用ROWID来进行单记录定位速度是最快的。
有受限的(orace8g以前)和 扩展的(oracle8g之后)两种形式,
受限的rowid:
文件编号(10bit) + 块编号(22bit) + 行编号(16bit) ,6个字节的存储空间
扩展的rowid:
数据对象编号(32bit) + 文件编号(10bit) + 块编号(22bit) + 行编号(16bit) ,10个字节的存储空间
rowid是base64编码的,用A~Z a~z 0~9 + /共64个字符表示。A表示0,B表示1,……,a表示26,……,0表示52,……,+表示62,/表示63可以将其看做一个64进制的数。
扩展的rowid也完全兼容受限的rowid
对rowid分析比较好的一些链接
http://space.itpub.net/?uid-25744374-action-viewspace-itemid-729897
http://www.cuug.com/xueyuanzhuanqu/jishuwenzhang/201110/jishuwenzhang-1147.html
2.实战
1)rownum在分页,查询中用到较多
where之后也只能rownum=1或<=n
2)rowid 在删除重复记录时
DELETE FROM EMP E WHERE E.ROWID > (SELECT MIN(X.ROWID)FROM EMP X WHERE X.EMP_NO = E.EMP_NO) ,而且比较高效;通过rowid快速定位到某记录,。。。
也可以通过dbms_rowid这个包得到rowid的详细信息;
还有rowid的一些函数ROWIDTOCHAR ,ROWIDTONCHAR,CHARTOROWID结合实际使用。
感受:之前对rowid有过了解,当并未深入;遇到时也只是以解决实际问题为主,但发现那并不是一个好的做法,而且之后对它也只是个懵懂的感觉,查一些资料当时会理解但还是会忘。感觉还是写下来比较好,也是个熟悉,总结的过程。实际的工作开发中并没有这样及时总结和学习的一种习惯,渐渐发现这并非明智之举,一些东西总得沉淀一下,要不永远不是自己的。
上面一点小感,希望跟大家有所共鸣。
分享到:
相关推荐
Oracle学习笔记(rownum和rowid),有具体的代码案例讲解rownum和rowid
举例介绍在oracle中rownum和rowId的不同以及使用方法
对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<、、!=),并非说用>,>=,=,between..and 时会提示SQL语法错误,而是经常是查不出一条记录来,还会出现似乎是莫名其妙的结果来...
本文主要是以实例形式介绍了Oracle查询中rownum与rowid的不同之处,以及以假设的方式为例,查询条件为rownum = 2,在查询出第一条记录时的具体内容的介绍。 在查询中,我们可以注意到,类似于 select xx from ...
oracle_SQL中rowid与rownum的使用
oracle_SQL中ROWID与ROWNUM的使用 很有用哦
oracle 数据库 rowid与rownum的使用
oracle rowid rownum 等组成原理
oracle_SQL中 rowid 和rownum的使用
ORACLE 中ROWNUM用法总结!数据库管理员及程序开发员必看。
Hint.pdf Oracle中rowid与rownum的使用.pdf Oracle优化 之 索引.pdf Oracle优化器.pdf STATSPACK详解.pdf 学用ORACLE_AWR和ASH特性.pdf 执行计划.pdf
oracle数据库伪列的介绍,让你明白rownum和rowid的一些区别。
37. 如何在oracle7和oracle8之间exp-imp数据 38. 如何在Windows 2000下将Oracle完全卸载 39. 如何正确建立TYPE、partition(分区) 40. 如何正确利用Rownum来限制查询所返回的行数 41. 什么是ROWID,为什么需要...
这是我自己学习oracle的时候,写的代码案例和笔记(rownum和rowid、嵌套表、可变数组、闪回、事务、索引、备份和恢复、用户创建和权限授予、序列和同义词、设计范式等等知识点),大家可以作为参考!
8、ROWNUM-TOP-N分析 9、相关子查询和非相关子查询 10、增强GROUP BY 11、分析函数(ANALYTICAL FUNCTIONS) 12、ROWID的使用 13、ORACLE 10G正则表达式 14、使用HINT 15、PARITION分区 16、并行操作 17、扩展DDL和...
掌握Oracle中rowid,rownum的使用,掌握ORACLE分页语句的写法,掌握ORACLE存储过程的创建和使用,
4. Oracle用户和权限 4.1用户和权限 4.2角色 第2章 SQL数据操作和查询 1. SQL简介 2. 查询 2.1查询结构 2.2查询顺序 . 2.3聚合函数 . 3. 创建表和约束 3.1 Oracle常用数据类型 3.2创建表 3.3表的约束 4....
在Oracle中,我们可以使用RowNum函数、Minus运算符、Subquery和Top-N查询来实现分页查询。这些方法可以根据不同的需求选择合适的方法来实现分页查询。在开发中,我们需要根据实际情况选择合适的方法来实现分页查询。