数据读取

首先数据块读入到Buffer Cache中,并将其放在LRU(Last Recently Used)链表的MRU(Most Recently Used)端,当需要再次访问该块时可以直接从buffer cache中读取,

如果有新的数据需要被读入Buffer Cache中,而Buffer Cache又没有足够的空闲空间,Oracle就根据LRU算法将LRU链表中LRU端的数据置换出去。当这些数据被再次访问到时,需要重新从磁盘读入。

当发生全表扫描(FullTable Scan)时,用户进程读取表的数据块,并将他们放在LRU链表的LRU端(和上面不同,不是放在MRU端)。这样做的目的是为了使全表扫描的数据尽快被移出。因为全表扫描一般发生的频率较低,并且全表扫描的数据块大部分在以后都不会被经常使用到。

而如果你希望全表扫描的数据能被cache住,使之在扫描时放在MRU端,可以通过在创建或修改表(或簇)时,指定CACHE参数。

逻辑读是指从buffercache中读取数据块。可以分为即时读(Current Read)和一致性读(Consistent Read)。注意:逻辑IO只有逻辑读,没有逻辑写。

·                 即时读

即时读即读取数据块当前的最新数据。任何时候在Buffer Cache中都只有一份当前数据块。即时读通常发生在对数据进行修改、删除操作时。这时,进程会给数据加上行级锁,并且标识数据为“脏”数据。

·                 一致性读

Oracle是一个多用户系统。当一个会话开始读取数据还未结束读取之前,可能会有其他会话修改它将要读取的数据。如果会话读取到修改后的数据,就会造成数据的不一致。一致性读就是为了保证数据的一致性。在Buffer Cache中的数据块上都会有最后一次修改数据块时的SCN。如果一个事务需要修改数据块中数据,会先在回滚段中保存一份修改前数据和SCN的数据块,然后再更新Buffer Cache中的数据块的数据及其SCN,并标识其为“脏”数据。当其他进程读取数据块时,会先比较数据块上的SCN和自己的SCN。如果数据块上的SCN小于等于进程本身的SCN,则直接读取数据块上的数据;如果数据块上的SCN大于进程本身的SCN,则会从回滚段中找出修改前的数据块读取数据。通常,普通查询都是一致性读。

查找数据

在一个查询操作中,大量的读操作都产生于数据的查找过程中。减少查找过程是我们优化IO性能问题的重要目标。

下面介绍几种主要的数据查找方式。

·                 Full Table Scan

当查询条件无法命中任何索引、或者扫描索引的代价大于全表扫描代价的某一比例时(由参数optimizer_index_cost_adj设定),Oracle会采用全表扫描的方式查找数据。当发生全表扫描时,Oracle会自下向上一次读取一定数量(由参数db_file_multiblock_read_count设定)的数据块,一直读取到高水位标志(HWM,High Water Mark)下。Full Table Scan会引起db file scattered read事件。

·                 INDEX UNIQUE SCAN

全表扫描查找数据的效率是非常低的。而索引能大幅提高查找效率。普通索引的数据结构是B-Tree,树的叶子节点中包含数据的ROWID,指向数据记录,同时还有指针指向前一个/后一个叶子节点。索引扫描每次读取一个数据块,索引扫描是“连续的”(Sequential)。当索引为UNIQUE索引时,每个叶子节点只会指向一条数据。如果Oracle能预知扫描结果只有0或1条记录时,会采用INDEX UNIQUE SCAN。当对Unique Index中的所有字段进行完全匹配时,会发生INDEX UNIQUE SCAN。

INDEX UNIQUE SCAN的查找过程如下:

1.              从数的根节点数据块开始查找;

2.              查找根节点块中所有key值中大于或等于要查找的值的最小key值;

3.              如果key值大于查找值,则继续查找这个key值之前一个key值所指向的子节点数据块;

4.              如果key值等于查找值,则继续查找这个key值所指向的子节点数据块;

5.              如果没有key值大于或等于查找值,则继续查找最大key值所指向的子节点数据块;

6.              如果继续查找的节点数据块是数一个分支节点,则重复2~4步;

7.              如果查找的节点是叶子节点数据块,则在数据块中查找等于查找值的key值;

8.              如果找到相等的key值,则返回数据和ROWID;

9.              如果没找到相等的key值,则说明没有符合条件的数据,返回NULL。

·                 INDEX RANGE SCAN

如果通过索引查找数据时,Oracle认为会返回数据可能会大于1,会进行INDEX RANGE SCAN,例如Unique Index中字段不完全匹配查找时、非Unique Index查找时。

INDEX RANGE SCAN分为闭包(有前后查找边界)和非闭包(只有一边或者没有边界)。返回数据会依据索引增序排序,多个相同值则会按照ROWID的增序排序。以下的查找条件都是闭包的:

WHERE column = 'Value'

WHERE column like 'value%'

WHERE column between 'value1' and 'value2'

WHERE column in ('value1', 'value2')

以下查找条件非闭包:

WHERE column < 'value1'

WHERE column > 'value2'

闭包条件下的INDEX RANGE SCAN的查找过程如下:

1.              从数的根节点数据块开始查找;

2.              查找根节点块中所有key值中大于或等于要查找的起始值的最小key值;

3.              如果key值大于起始值,则继续查找这个key值之前一个key值所指向的子节点数据块;

4.              如果key值等于起始值,则继续查找这个key值所指向的子节点数据块;

5.              如果没有key值大于或等于起始值,则继续查找最大key值所指向的子节点数据块;

6.              如果继续查找的节点数据块是数一个分支节点,则重复2~4步;

7.              如果查找的节点是叶子节点数据块,则在数据块中大于或等于要查找的起始值的最小key值;

8.              如果Key值小于或等于结束值,则:如果所有Key字段都符合WHERE字句中的查找条件,则返回数据和ROWID;否则继续查找当前叶子节点所指向的右边的叶子节点。

INDEX UNIQUE SCAN和INDEX RANGE SCAN都会引起db file sequential read事件。

·                 TABLE ACCESS BY INDEXROWID

当发生索引扫描时,如果需要返回的字段都在索引上,则直接返回索引上的数据,而如果还需要返回非索引上的字段的值,Oracle则需要根据从索引上查找的ROWID到对应的数据块上取回数据,这时就是TABLE ACCESS BY INDEX ROWID。

·                 INDEX FAST FULL SCAN& INDEX FULL SCAN

索引快速全扫描和全表扫描类似,一次读取db_file_multiblock_read_count个数据块来描所有索引的叶子节点。INDEX FAST FULLSCAN和其他索引扫描不同,它不会从树的根节点开始读取,而是直接扫描所有叶子节点;也不会一次读取一个数据块,而是一次读取db_file_multiblock_read_count个数据块。INDEX FAST FULLSCAN会引起db filescattered read事件。

在某些情况下,如db_file_multiblock_read_count值过小、强制使用索引扫描时,会发生INDEX FULL SCAN。INDEX FULL SCAN和INDEX FAST FULL SCAN不同,它是一种索引扫描,按照B-Tree的查找法从树的根节点开始扫描,遍历整棵树,并且一次读取一个数据块。它会引起db file sequential read事件。

原文地址:http://wsql.iteye.com/blog/1194357

转载于:https://www.cnblogs.com/zhwl/p/3708494.html

oracle中的数据读取与查找相关推荐

  1. MyBatis在Oracle中插入数据并返回主键的问题解决

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 前言:我早期用过这个方法,但是返回的依旧是影响行数,不是主键. 只是这种写法可以达到我要的效果: 用 ...

  2. android libbfaac.so,Android中Json数据读取与创建

    一:  Json的特性和在数据交互中的地位就不用说了,直接看案例. 首先在android studio中创建assets文件目录,用于存放Json数据文件,android studio 1.3 默认项 ...

  3. oracle中的数据对象

    oracle中的数据对象有表.视图.索引.序列等 表的相关操作 1.创建表 方式一: 方式二:create table person( create table person1 id number(1 ...

  4. oracle删除的数据没有commit,在Oracle中误删除数据后并commit后的数据恢复办法

    在Oracle中误删除数据后并commit后的数据恢复办法 背景:表A数据误操作,被delete了,恢复. --1.先备份A表当前数据. --2.查询某 在Oracle中误删除数据后并commit后的 ...

  5. excel查询oracle数据库,用Excel直接查询Oracle中的数据

    一般情况下,我们如果想要把Oracle当中查询的数据保存为Excel文件,一般都是使用的是PL/SQLDeveloper,本文就给大家介绍一下关于用Excel直接查询Oracle中的数据的内容. 事实 ...

  6. oracle匹配excel数据,如何用Excel直接查询Oracle中的数据

    如何用Excel直接查询Oracle中的数据 关注:275  答案:2  mip版 解决时间 2021-01-11 08:35 提问者╬═掵中注定 2021-01-10 16:43 如何用Excel直 ...

  7. python怎么读取csv的一部分数据_python批量读取csv文件 如何用python将csv文件中的数据读取成数组...

    如何用python把多个csv文件数据处理后汇总到新csv文件你看这月光多温柔,小编转头还能看见你,一切从未坍塌. 可以用pandas读取数据,首先把文件方同一个文件价里,然后对当前文件价的所有内容循 ...

  8. 集合中的数据存入到文件中,文件中的数据读取到集合中

    * Map<String ,Integer> map = new LinkedHashMap<>(); * map.put("摩卡",30); * map. ...

  9. oracle中的数据集合操作

    一.数据更新操作 DML语法中主要包括两个内容:查询与更新,更新主要包括:增加数据.修改数据.删除数据.其中这些操作是离不开查询的.         1.增加数据 语法:INSERT INTO 表名称 ...

最新文章

  1. Java正则入门(1)——去除字符串头尾空格
  2. erlang r19里面的mnesia_ext
  3. Jessica's Reading Problem
  4. Visual C++6.0安装教程(win10版)及“应用程序无法正常启动(0x0150002)”解决办法
  5. Leaflet中使用Leaflet.AnimatedMarker插件实现要素轨迹移动
  6. VTK:可视化之ComplexV
  7. Hologres揭秘:深度解析高效率分布式查询引擎
  8. GNU C __attribute__ 机制简介
  9. 探索未知种族之osg类生物---呼吸分解之更新循环一
  10. 例子:Basic Lens sample
  11. wpf开发仿真3d软件_3D体验平台品牌应用——SOLIDWORKS?
  12. Java中ArrayList类的用法
  13. 使用struts2完成ckeditor和图片上传
  14. QT添加资源文件并使用
  15. 中国社会为何多犬儒?
  16. 解决Visio另存为(或者导出)pdf字符间距变化/不均等字母间距的问题
  17. WINDOWS远程连接显示“请稍后”
  18. 提高工作效率的15个技巧
  19. linux中各种error意思
  20. 【videojs】videojs自定义全屏按钮 | videojs全屏移动端弊端 | 创建videojs菜单

热门文章

  1. 值计算公式_板式换热器选型,K值是关键点!
  2. html按钮的下拉菜单,按钮下拉菜单
  3. 【Flink】Flink 流计算 容错 source节点进行数据容错
  4. 【Elasticsearch】估算在 Elasticsearch 中存储文档的成本
  5. 【Elasticsearch】elasticsearch 压缩索引 shrink
  6. 80-040-000-原理-MySQL的 ICP
  7. 源代码:spark-shell解读
  8. 【Mac】Mac下安装MySQL优化工具 percona-toolkit 报错 Error: Failed to download resource openssl@1.1
  9. Mac电脑开机出现带问号的文件夹并且闪烁 apple.com/support -2003F
  10. 【hue】Bad status: 3 (PLAIN auth failed: Error validating LDAP user)