文档章节

Oracle中的rowid

小强斋太
 小强斋太
发布于 2016/11/09 20:05
字数 1335
阅读 7
收藏 0
点赞 0
评论 0

ROWID是ORACLE中的一个重要的概念。用于定位数据库中一条记录的一个相对唯一地址值。通常情况下,该值在该行数据插入到数据库表时即被确定且唯一。ROWID它是一个伪列,它并不实际存在于表中。它是ORACLE在读取表中数据行时,根据每一行数据的物理地址信息编码而成的一个伪列。所以根据一行数据的ROWID能找到一行数据的物理地址信息。从而快速地定位到数据行。数据库的大多数操作都是通过ROWID来完成的,而且使用ROWID来进行单记录定位速度是最快的。

要理解索引,必须先搞清楚ROWID。

B-Tree索引的每个索引条目具有两个字段。第一个字段表示索引的键值,对于单列索引来说是一个值;而对于多列索引来说则是多个值组合在一起的。第二个字段表示键值所对应的记录行的ROWID。所以索引能加快查询速度!

索引值→ROWID->将ROWID换算成一行数据的物理地址->得到一行数据

一、ROWID的格式:

clip_image001

第一部分6位表示:该行数据所在的数据对象的 data_object_id
第二部分3位表示:该行数据所在的相对数据文件的id;
第三部分6位表示:该数据行所在的数据块的编号;
第四部分3位表示:该行数据的行的编号;

索引就是保存了rowid后三个部分的信息。索引是物理存在的,而rowid是伪列。所以索引可以用来快速地定位到数据行。

data_object_id

下面以SAKILA数据库的ACTOR表为例

这里我们要注意将 data_object_id  object_id 区分开来,前者是oracle为它的每一个对象唯一分配的id,而后者与表ACTOR对应的“段”有关,是存放表tt的段的id,也就是与存放表tt中数据的物理位置有关:

select owner,object_id,data_object_id,status from dba_objects where object_name='ACTOR';

clip_image002

alter table ACTOR move tablespace users;

select owner,object_id,data_object_id,status from dba_objects where object_name='ACTOR';

clip_image003

我们看到当表ACTOR move到了users表空间时,段发生了改变,物理位置发生了变化,从而 DATA_OBJECT_ID 也发生了变化。我们知道表是存放在“表段”中的,索引是存放在“索引段”中的。DATA_OBJECT_ID就是表示存放数据的“数据段对象的id”

相对文件编码

关于相对文件编码和绝对文件编号:相对文件id是指相对于表空间,在表空间唯一,绝对文件是指相当于全局数据库而言的,全局唯一;

select file_name,file_id,relative_fno from dba_data_files;

clip_image004

rowid采用64进制来编码

编码方法是:A~Z表示0到25;a~z表示26到51;0~9表示52到61;+表示62;/表示63;刚好64个字符。

Base64编码表

码值 字符   码值 字符   码值 字符   码值 字符
0 A 16 Q 32 g 48 w
1 B 17 R 33 h 49 x
2 C 18 S 34 i 50 y
3 D 19 T 35 j 51 z
4 E 20 U 36 k 52 0
5 F 21 V 37 l 53 1
6 G 22 W 38 m 54 2
7 H 23 X 39 n 55 3
8 I 24 Y 40 o 56 4
9 J 25 Z 41 p 57 5
10 K 26 a 42 q 58 6
11 L 27 b 43 r 59 7
12 M 28 c 44 s 60 8
13 N 29 d 45 t 61 9
14 O 30 e 46 u 62 +
15 P 31 f 47 v 63 /

二、使用rowid访问数据的执行计划

SELECT t.*, ''||t.ROWID FROM "SAKILA"."ACTOR" t;

clip_image005

EXPLAIN PLAN FOR                                                                                         
select * FROM ACTOR where rowid='AAAYEVAAJAAAACrAAA';  
select * from table(DBMS_XPLAN.DISPLAY)

image

三、例子:如何从rowid计算得到obj#,rfile#,block#,row#

我们演示一下具体的计算方法:

SELECT t.*, ''||t.ROWID FROM "SAKILA"."ACTOR" t;

clip_image005

表sakila的 data_object_id 为 AAAYEVAAJAAAACrAAA的前6位:AAAYEV,那么我们来计算一下 AAAYEV的值到底是多少:

查询Base64编码表

码值 字符
0 A
24 Y
4 E
21 V

select 24 * 64 * 64 + 4 * 64 + 21 from dual;

AAAYEV=24 * 64 * 64 + 4 * 64 + 21=98581

然后我们查询字典表,看两种方法得到的值是否相等:

select owner,object_id,data_object_id,status from dba_objects where object_name='ACTOR';

clip_image003[1]

我们看到通过rowid计算得到的data_object_id和通过字典表查到的值相等!

表ACTOR的相对文件编号为 AAAYEVAAJAAAACrAAA 的中的 AAJ,显然查表可知 AAJ= 9;

我们在再来查询字典表:

clip_image006

可以看到字典表显示relative_fno为9的数据文件为C:\APP\ORACLE\ORADATA\ORCL\PDBORCL\SAMPLE_SCHEMA_USERS01.DBF

查询当前数据库中的users表空间和对应的数据文件

select file_name,tablespace_name from dba_data_files;

clip_image007

两者结果一致。

而我们前面执行过:alter table ACTOR move tablespace users;所以两种方式得到的结果是一致的。

表ACTOR中的第一行数据存放的block的编号为 AAAYEVAAJAAAACrAAA 中的 AAAACr,而AAAACr =2*64+43=171
表ACTOR中的第一行数据存放的行的编号为AAAYEVAAJAAAACrAAA 中的 AAA,显然值为0,即第一行。

我们也可以通过Oracle提供的存储过程来计算出上面的值:

SELECT

dbms_rowid.rowid_object (ROWID) data_object_id,

dbms_rowid.rowid_relative_fno (ROWID) relative_fno,

dbms_rowid.rowid_block_number (ROWID) block_no,

dbms_rowid.rowid_row_number (ROWID) row_no

FROM

ACTOR;

clip_image008

显然这个结果和我们手动计算的结果是一致的。

参考

Oracle中的rowid学习

oracle中rowid的用法

© 著作权归作者所有

共有 人打赏支持
小强斋太
粉丝 0
博文 181
码字总数 0
作品 0
广州
Rowid和Rownum的区别

Rowid和Rownum对于数据库开发人员来说基本很少用到,因为在企业数据库开发中大多都是进行数据批处理,但是对于其他数据库人员来说还是会用到的。 rowid和rownum都是虚列,但含义完全不同。r...

wangergui ⋅ 2017/02/23 ⋅ 0

mysql与oracle去重方案的异同,mysql处于学习阶段不太熟悉,最后有两个解决不了,求大神帮忙补充上

去重查询语句 oracle: select * from table1 a where rowid in (select max(rowid) from table1 b where a.id = b.id) mysql: select a.id,* from table1 a group by a.id 查询重复的语句 or......

混分小菜鸟 ⋅ 2015/03/20 ⋅ 2

《Oracle Database Concepts 11g Release 2》读书笔记(2)...

Table(P36-P50) 1. 定义 Table 是 oracle中数据的基本组成单位. Oracle 中定义了两种类型的 Table: 1) Relation Table 最常用的 table 类型,列由基本数据类型组成. 每个 Realation Table 是以...

sailtseng ⋅ 2012/06/07 ⋅ 0

Oracle 中的rowid

Oracle中的每个表都有一个rowid,它是一个18位字符组成字符串,例:AAANgBAABAAAO/KAAA.它包含的字符串由A-Z,a-z,0-9,+,/这些字符组成.是64进制. 其中A-Z对应0-25,a-z对应26-51,0-9对应52-61,+...

晨曦之光 ⋅ 2012/04/25 ⋅ 0

oracle下快速删除重复的记录,借监并且总结了一下

oracle下快速删除重复的记录 假设表名为Tbl,表中有三列col1,col2,col3,其中col1,col2是主键,并且,col1,col2上加了索引。 1、通过创建临时表 可以把数据先导入到一个临时表中,然后删...

余二五 ⋅ 2017/11/14 ⋅ 0

ORACLE的ORDERBY非稳定的排序

提一个问题: oracle在order by 排序时,是稳定排序算法吗? 发现用一个type进行排序后,做分页查询,第一页的数据和第二页的数据有重复 怀疑是order by 时,两次排列的顺序不一致 看到业务描...

王小明123 ⋅ 2012/11/02 ⋅ 6

SQL优化常用方法42

使用提示(Hints) 对于表的访问,可以使用两种Hints. FULL 和 ROWID FULL hint 告诉ORACLE使用全表扫描的方式访问指定表. 例如: SELECT /+ FULL(EMP) / FROM EMP WHERE EMPNO = 7893; ROWID hi...

inzaghi1984 ⋅ 2017/12/17 ⋅ 0

Oracle bbed 使用

1:安装: 11g R2 版的 cd $ORACLE_HOME/ find . -name ins_rdbms.mk cd rdbms/lib make -f insrdbms.mk $ORACLEHOME/rdbms/lib/bbed 在11g会报错。需要在网上下载三个文件。或者你有10g 的库......

jesnridy ⋅ 2014/07/17 ⋅ 0

理解oracle ROWID

数据存放在数据文件中,其属性会随着存储而确定,这些属性包括:在哪个数据文件?属于哪个对象?所在的数据块?行号? 将这些属性合并起来就构成了oracle的ROWID。 所以,rowid详细的记录了数...

长平狐 ⋅ 2012/09/19 ⋅ 0

【BBED】BBED模拟并修复ORA-08102错误

【BBED】BBED模拟并修复ORA-08102错误 1.1 BLOG文档结构图 1.2 前言部分 1.2.1 导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识,~...

lhrbest ⋅ 2017/09/22 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

熊掌号收录比例对于网站原创数据排名的影响[图]

从去年下半年开始,我在写博客了,因为我觉得业余写写博客也还是很不错的,但是从2017年下半年开始,百度已经推出了原创保护功能和熊掌号平台,为此,我也提交了不少以前的老数据,而这些历史...

原创小博客 ⋅ 59分钟前 ⋅ 0

LVM讲解、磁盘故障小案例

LVM LVM就是动态卷管理,可以将多个硬盘和硬盘分区做成一个逻辑卷,并把这个逻辑卷作为一个整体来统一管理,动态对分区进行扩缩空间大小,安全快捷方便管理。 1.新建分区,更改类型为8e 即L...

蛋黄Yolks ⋅ 今天 ⋅ 0

Hadoop Yarn调度器的选择和使用

一、引言 Yarn在Hadoop的生态系统中担任了资源管理和任务调度的角色。在讨论其构造器之前先简单了解一下Yarn的架构。 上图是Yarn的基本架构,其中ResourceManager是整个架构的核心组件,它负...

p柯西 ⋅ 今天 ⋅ 0

uWSGI + Django @ Ubuntu

创建 Django App Project 创建后, 可以看到路径下有一个wsgi.py的问题 uWSGI运行 直接命令行运行 利用如下命令, 可直接访问 uwsgi --http :8080 --wsgi-file dj/wsgi.py 配置文件 & 运行 [u...

袁祾 ⋅ 今天 ⋅ 0

JVM堆的理解

在JVM中,我们经常提到的就是堆了,堆确实很重要,其实,除了堆之外,还有几个重要的模块,看下图: 大 多数情况下,我们并不需要关心JVM的底层,但是如果了解它的话,对于我们系统调优是非常...

不羁之后 ⋅ 昨天 ⋅ 0

推荐:并发情况下:Java HashMap 形成死循环的原因

在淘宝内网里看到同事发了贴说了一个CPU被100%的线上故障,并且这个事发生了很多次,原因是在Java语言在并发情况下使用HashMap造成Race Condition,从而导致死循环。这个事情我4、5年前也经历...

码代码的小司机 ⋅ 昨天 ⋅ 2

聊聊spring cloud gateway的RetryGatewayFilter

序 本文主要研究一下spring cloud gateway的RetryGatewayFilter GatewayAutoConfiguration spring-cloud-gateway-core-2.0.0.RC2-sources.jar!/org/springframework/cloud/gateway/config/G......

go4it ⋅ 昨天 ⋅ 0

创建新用户和授予MySQL中的权限教程

导读 MySQL是一个开源数据库管理软件,可帮助用户存储,组织和以后检索数据。 它有多种选项来授予特定用户在表和数据库中的细微的权限 - 本教程将简要介绍一些选项。 如何创建新用户 在MySQL...

问题终结者 ⋅ 昨天 ⋅ 0

android -------- 颜色的半透明效果配置

最近有朋友问我 Android 背景颜色的半透明效果配置,我网上看资料,总结了一下, 开发中也是常常遇到的,所以来写篇博客 常用的颜色值格式有: RGB ARGB RRGGBB AARRGGBB 这4种 透明度 透明度...

切切歆语 ⋅ 昨天 ⋅ 0

CentOS开机启动subversion

建立自启动脚本: vim /etc/init.d/subversion 输入如下内容: #!/bin/bash## subversion startup script for the server## chkconfig: 2345 90 10# description: start the subve......

随风而飘 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部