WEB开发网
开发学院数据库Oracle 存取Oracle当中扫描数据的方法 阅读

存取Oracle当中扫描数据的方法

 2008-08-23 12:42:30 来源:WEB开发网   
核心提示:Oracle 是一个面向Internet计算环境的数据库,它是在数据库领域一直处于领先地位的甲骨文公司的产品,存取Oracle当中扫描数据的方法,可以说Oracle关系数据库系统是目前世界上流行的关系数据库管理系统,本文将对oracle当中扫描数据的存取方法进行介绍,一次I/O只能读取一个数据块,我们会经常在执行计划中

Oracle 是一个面向Internet计算环境的数据库。它是在数据库领域一直处于领先地位的甲骨文公司的产品。可以说Oracle关系数据库系统是目前世界上流行的关系数据库管理系统,本文将对oracle当中扫描数据的存取方法进行介绍。

1) 全表扫描(Full Table Scans, FTS)

为实现全表扫描,Oracle读取表中所有的行,并检查每一行是否满足语句的WHERE限制条件一个多块读操作可以使一次I/O能读取多块数据块(db_block_multiblock_read_count参数设定),而不是只读取一个数据块,这极大的减少了I/O总次数,提高了系统的吞吐量,所以利用多块读的方法可以十分高效地实现全表扫描,而且只有在全表扫描的情况下才能使用多块读操作。在这种访问模式下,每个数据块只被读一次。

使用FTS的前提条件:在较大的表上不建议使用全表扫描,除非取出数据的比较多,超过总量的5% -- 10%,或你想使用并行查询功能时。

使用全表扫描的例子: 

  SQL>explainplanforselect*fromdual;
  QueryPlan
  SELECTSTATEMENT[CHOOSE]Cost=
  TABLEACCESSFULLDUAL

2) 通过ROWID的表存取(Table Access by ROWID或rowid lookup)

行的ROWID指出了该行所在的数据文件、数据块以及行在该块中的位置,所以通过ROWID来存取数据可以快速定位到目标数据上,是Oracle存取单行数据的最快方法。

这种存取方法不会用到多块读操作,一次I/O只能读取一个数据块。我们会经常在执行计划中看到该存取方法,如通过索引查询数据。

使用ROWID存取的方法: 

   SQL>explainplanforselect*fromdeptwhererowid='AAAAyGAADAAAAATAAF';
  QueryPlan
  SELECTSTATEMENT[CHOOSE]Cost=1
  TABLEACCESSBYROWIDDEPT[ANALYZED]

1 2 3 4  下一页

Tags:存取 Oracle 当中

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接