文档章节

表访问方式---->通过ROWID访问表(table access by ROWID)

小强斋太
 小强斋太
发布于 2016/11/09 20:07
字数 979
阅读 6
收藏 0

通过ROWID访问表(table access by ROWID)

       ROWID是一个伪列,即是一个非用户定义的列,而又实际存储于数据库之中。每一个表都有一个ROWID列,一个ROWID值用于唯一确定数据库表中的的一条记录。因此通过ROWID 方式来访问数据也是 Oracle 数据库访问数据的实现方式之一。一般情况下,ROWID方式的访问一定以索引访问或用户指定ROWID作为先决条件,因为所有的索引访问方式最终都会转换为通过ROWID来访问数据记录。(注:index full scan 与index fast full scan除外)由于Oracle ROWID能够直接定位一条记录,因此使用ROWID方式来访问数据,极大提高数据的访问效率

ROWID扫描是指Oracle在访问目标表里的数据时,直接通过数据所在的ROWID去定位并访问这些数据。

从严格意义上来说,Oracle中的ROWID扫描有两层含义:一种是根据用户在SQL语句中输入的ROWID的值直接去访问对应的数据行记录;另外一种是先去访问相关的索引,然后根据访问索引后得到的ROWID再回表去访问对应的数据行记录。

对Oracle中的堆表而言,我们可以通过Oracle内置的ROWID伪列得到对应行记录所在的ROWID的值(注意,这个ROWID只是一个伪 列,在实际的表块中并不存在该列),然后我们还可以通过DBMS_ROWID包中的相关方法(dbms_rowid.rowid_object,dbms_rowid.rowid_relative_fno、dbms_rowid.rowid_block_number和 dbms_rowid.rowid_row_number)将上述ROWID伪列的值翻译成对应数据行的实际物理存储地址。

参考:Oracle中的rowid

我们来看一个使用ROWID伪列和DBMS_ROWID包的实例。执行如下SQL,查询表EMP中的所有记录:

SCOTT@PDBORCL>  select empno, ename, rowid, dbms_rowid.rowid_object(rowid)||'_'||dbms_rowid.rowid_relative_fno(rowid) ||
 '_' || dbms_rowid.rowid_block_number(rowid) || '_' || dbms_rowid.rowid_row_number(rowid) location from emp;

     EMPNO ENAME      ROWID              LOCATION
---------- ---------- ------------------ -------------------------------------------------------------------------------
------------------------------------------------------------------------------------
      7369 SMITH      AAAWh/AAJAAAACVAAA 92287_9_149_0
      7499 ALLEN      AAAWh/AAJAAAACVAAB 92287_9_149_1
      7521 WARD       AAAWh/AAJAAAACVAAC 92287_9_149_2
      7566 JONES      AAAWh/AAJAAAACVAAD 92287_9_149_3
      7654 MARTIN     AAAWh/AAJAAAACVAAE 92287_9_149_4
      7698 BLAKE      AAAWh/AAJAAAACVAAF 92287_9_149_5
      7782 CLARK      AAAWh/AAJAAAACVAAG 92287_9_149_6
      7788 SCOTT      AAAWh/AAJAAAACVAAH 92287_9_149_7
      7839 KING       AAAWh/AAJAAAACVAAI 92287_9_149_8
      7844 TURNER     AAAWh/AAJAAAACVAAJ 92287_9_149_9
      7876 ADAMS      AAAWh/AAJAAAACVAAK 92287_9_149_10
      7900 JAMES      AAAWh/AAJAAAACVAAL 92287_9_149_11
      7902 FORD       AAAWh/AAJAAAACVAAM 92287_9_149_12
      7934 MILLER     AAAWh/AAJAAAACVAAN 92287_9_149_13

已选择 14 行。

SCOTT@PDBORCL>

从上述显示的内容中我们可以看出,EMPNO为7369的行记录所对应的ROWID伪列的值为"AAAWh/AAJAAAACVAAA",使用 DBMS_ROWID包对该伪列翻译后的值为"92287_9_149_0",这表示EMPNO为7369的行记录,对象编号为92287,实际的物理存储地址位于9号文件的第149个数据块的第0行记录(数据块里数据行记录的记录号从0开始算起)。

select file_name,file_id,relative_fno from dba_data_files where relative_fno=9;

SYS@PDBORCL> select file_name,file_id,relative_fno from dba_data_files where relative_fno=9;

FILE_NAME                                                                        FILE_ID     RELATIVE_FNO
-----------------------------------------------------------------------------------------------------------------------------------------------C:\APP\ORACLE\ORADATA\ORCL\PDBORCL\SAMPLE_SCHEMA_USERS01.DBF                         9            9

上述ROWID伪列的值是可以直接在SQL语句的where条件中使用的,这就是Oracle中ROWID扫描的两层含义中的第一种:根据用户在SQL语句中输入的ROWID的值直接去访问对应的数据行记录。

现在执行一次如下使用ROWID伪列的SQL:

SCOTT@PDBORCL> select empno,ename from emp where rowid='AAAWh/AAJAAAACVAAA';

     EMPNO ENAME
---------- ----------
      7369 SMITH

从上述显示的内容中我们可以看出,Oracle确实是通过ROWID伪列(即rowid='AAAWh/AAJAAAACVAAA')直接访问到了EMPNO为7369的行记录。

执行计划如下:

image

查询计划中说明该查询是的表访问方式是”TABLE ACCESS BY USER ROWID“,也就是直接通过USER ROWID来访问

参考:

Oracle中的rowid

ROWID扫描

Oracle ROWID 方式访问数据库

本文转载自:http://www.cnblogs.com/xqzt/p/4464205.html

共有 人打赏支持
小强斋太
粉丝 0
博文 181
码字总数 0
作品 0
广州
SQL优化常用方法42

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

inzaghi1984
2017/12/17
0
0
ORACLE SQL性能优化系列 (一) black_snai

ORACLE SQL性能优化系列 (一) 原创 2003年07月21日 18:34:00 标签: oracle / sql / 性能优化 / 优化 / 数据库 / statistics <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:......

rootliu
04/12
0
0
SQL优化常用方法26

索引的操作 ORACLE对索引有两种访问模式. 索引唯一扫描 ( INDEX UNIQUE SCAN) 大多数情况下, 优化器通过WHERE子句访问INDEX. 例如: 表LODGING有两个索引 : 建立在LODGING列上的唯一性索引LOD...

inzaghi1984
2017/12/15
0
0
FIRST_ROWS优化模式语言排序模糊匹配问题

标题比较长,不过只有这样才能把问题描述清楚。 问题详细描述为,在FIRST_ROWS优化模式下,将会话排序和比较方式设置为语义模式,即忽略大小写模式,对字段进行LIKE模糊查询,可能导致错误的...

晨曦之光
2012/03/09
0
0
浅分析Oracle语句优化规则

今天博主说说关于Oracle语句优化问题,废话不多说直接上优化内容。希望对大家有所帮助。 1. 选用适合的ORACLE优化器 ORACLE的优化器共有3种: a. RULE (基于规则) b. COST (基于成本) c. CH...

xiaole0313
2015/07/22
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Spring MVC 通过@Value注解读取.properties配置内容

第一步: 在applicationContext.xml配置: <bean id="configProperties" class="org.springframework.beans.factory.config.PropertiesFactoryBean"> <property name="locations">......

wangyanbao
7分钟前
0
0
Rancher 2.1全面发布,优化Kubernetes集群运维

GitLab支持、CICD优化、项目配额管理、驱散容器功能等等,Rancher 2.1给你带来一大票惊喜新功能!还有备着【千元大奖】的用户体验计划等你来参与! Rancher 2.1已于近日全面发布! Rancher ...

RancherLabs
13分钟前
0
0
如何优雅的给淘客/京东及拼多多的代理(会员)发工资(佣金)

前段时间有一些做淘客和京东推广的朋友问我能不能开发一个代付系统,这样他们可以用来给代理和网站会员发工资,他们现在还是用的人工手动打款,不仅效率慢,而且还容易出错,我一想,嗯,不难...

千龍
18分钟前
0
0
try-catch-finally

try-catch-finally 一.执行顺序 try-catch-finally 包含的代码块,当 try 里面的代码出现异常的时候,会进入 catch 中,finally 代码块则在最后被执行,即 无论是否出现异常,finally 里面的...

tsmyk0715
24分钟前
1
0
【编程架构实战】——Java并发包基石-AQS详解

目录 1 基本实现原理 1.1 如何使用 1.2 设计思想 2 自定义同步器 2.1 同步器代码实现 2.2 同步器代码测试 3 源码分析 3.1 Node结点 3.2 独占式 3.3 共享式 4 总结   Java并发包(JUC)中提...

java知识分子
24分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部