什么是访问路径?表扫描数据的时候使用了什么方式,这个方式就是访问路径

1.全表扫描
TABLE ACCESS FULL 全表扫描,多块读,等待事件:db file scattered read
如果是并行全表扫描,等待事件: direct path read
11g 有个新特征,在进行全表扫描的时候也会产生 direct path read
在OLTP环境中要通过 10949 event 禁止该新特征
在OLAP环境中可以不用禁止
如果表上面有大量的行迁链接,会是单块读 等待事件表现为db file sequential read
如果表上面发生了一个大事物,全表扫描会从UNDO读取前镜像,也会是单块读
HINT: FULL(表名/别名)
等待事件:db file scattered read 在SGA中
等待事件:direct path read 在PGA中

禁用oracle11g的新特性,有两种方法
a.event 10949设置后,可以禁用direct path read。
开启
SQL> ALTER session SET EVENTS '10949 TRACE NAME CONTEXT FOREVER';
禁用
SQL> ALTER session SET EVENTS '10949 TRACE NAME CONTEXT off';

b.通过设置隐含参数_serial_direct_read来设置是否启用direct path read
禁用
SQL>alter session set "_serial_direct_read"=never;
开启(默认)
SQL> alter session set "_serial_direct_read"=auto;

2.索引唯一扫描
INDEX UNIQUE SCAN 索引唯一扫描。单块读 只可能发生在unique index/primary key 等值查找
等待事件:db file sequential read 但是你几乎看不到,因为只读一条数据
HINT 无需指定,有索引会自动走INDEX UNIQUE SCAN
索引唯一扫描在不回表的时候访问几个索引块?
索引高度这么多个块。

select * from t where id=10;返回一行数据,要扫描多少个块?
索引高度+1(在不发生行迁移连接的情况下)
索引高度+2(发生行迁移连接的情况)

3.索引范围扫描
INDEX RANGE SCAN 索引范围扫描。单块读 发生在对unique index/primary key 进行范围查找,
对non-unique index进行等值查找,范围查找
等待事件:db file sequential read 如果你监控某个SQL出现大量该等待事件,
有可能执行计划就有问题
HINT: INDEX(表名/别名 索引名)

在索引唯一扫描中很难捕获等待事件,因为只返回一条数据,单块读的时间为12ms,索引唯一扫描扫描索引高度这么多个块,返回一条数据

的时间小于1s,1s这个阈值是记录等待时间的要求,所以不会记录等待事件,这个阈值是ash的响应时间,什么是ash呢?
ASH以V$SESSION为基础,每秒采样一次,记录活动会话等待的事件。不活动的会话不会采样,采样工作由新引入的后台进程MMNL来完成。
那么在索引范围扫描中怎么能看见db file sequential read等待事件呢?
12ms*100等于1.2s超过了ash的阈值,就可以记录等待事件
100单块读,每个块包含1000条数据,就是10w条数据,也就是说通过索引范围扫描返回超过10w条数据时就会出现等待时间。

监控一个sql的等待事件
select (sysdate-logon_time)*24*60 minutes,username,machine,program,action,
status,inst_id,sid,serial#,event,p1,p2,p3,
row_wait_obj# obj#,row_wait_file# file#,row_wait_block# block#,sql_id,sql_child_number from gv$session where sql_id='XXX';

4.索引跳跃扫描
INDEX SKIP SCAN 索引跳跃扫描。单块读 只可能发生在组合索引上,引导列(组合索引第一列)没有包
含在where条件中,并且引导列基数很低。INDEX SKIP SCAN
一般来说只会返回少量数据,如果返回大量数据,说明该执
行计划可能有问题,也就是说索引建立不对。
等待事件:db file sequential read
HINT: INDEX_SS(表名/别名 索引名)

5.索引全扫描
INDEX FULL SCAN 索引全扫描。单块读 。它扫描的结果是有序的,因为索引是有序的。它通常发生在
下面几种情况(注意:即使SQL满足以下情况 不一定会走索引全扫描)
a. SQL语句有order by选项,并且order by 的列都包含
在索引中,并且order by 后列顺序必须和索引列顺序一致。
b. 在进行SORT MERGE JOIN的时候,如果要查询的列通过索
引就能获得,那就不必进行全表扫描了,另外也避免了排
序,因为INDEX FULL SCAN返回的结果已经排序。
c. 当查询中有GROUP BY,并且GROUP BY 的列包含在索引中。
等待事件:db file sequential read
HINT: INDEX(表名/别名 索引名)

索引全表扫描会扫描blevel+leaf个块

6.索引快速扫描
INDEX FAST FULL SCAN 索引快速全扫描。多块读 。当SQL要查询的数据能够完全从索引中获得,那么
Oracle就不会走全表扫描了,就会走索引快速全
扫描。索引快速全扫描类似全表扫描,它可以多块
读,并且可以并行扫描。
等待事件:db file scattered read
HINT:INDEX_FFS(表名/别名 索引名)

oracle学习----访问路径的更多相关文章

  1. ORACLE Index Lookup索引访问路径总结

    在ORACLE中,索引访问/查找(Index Lookup)路径有五种方式,分别为INDEX UNIQUE SCAN.INDEX RANGE SCAN.INDEX FULL SCAN.INDEX FA ...

  2. oracle 网络访问配置tnsnames.ora文件的路径

    转自:https://blog.csdn.net/jaray/article/details/22379811 oracle 网络访问配置tnsnames.ora文件的路径 oracle 9i  是: ...

  3. struts2学习二:Tomcat的部署目录和访问路径问题

    1:idea中配置tomcat后,那么最终的web工程发布到哪里去了?为什么在访问路径中不加工程名就可以访问? 1.1:因为tomcat有段时间没接触了,先回顾下tomcat的目录结构吧? 如图所示: ...

  4. day10(java web之request&respone&访问路径&编码问题)

    day10 请求响应流程图 response response概述 response是Servlet.service方法的一个参数,类型为javax.servlet.http.HttpServletR ...

  5. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  6. Oracle数据访问组件ODAC的安装方法

    Oracle数据访问组件ODAC(Oracle Data Access Components)顾名思义就是用来访问Oracle数据库的小程序.我们可以编程调用这些组件来实现在没有安装Oracle数据库 ...

  7. Oracle数据访问组件ODAC的安装方法:

    Oracle数据访问组件ODAC(Oracle Data Access Components)顾名思义就是用来访问Oracle数据库的小程序.我们可以编程调用这些组件来实现在没有安装Oracle数据库 ...

  8. Oracle学习指南

    Oracle学习指南 你走的那天,我决定不落泪,迎着风撑着眼帘用力不眨眼 创建数据库.创建用户.创建表空间.创建表.插入数据..... 1.用系统用户登录,任选系统用户 代码: >>sql ...

  9. Oracle学习系列1-7

    Oracle学习系列1 两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 3 ...

随机推荐

  1. hdu 4454 Stealing a Cake

    简单的计算几何: 可以把0-2*pi分成几千份,然后找出最小的: 也可以用三分: #include<cstdio> #include<cmath> #include<al ...

  2. 深入浅出Z-Stack 2006 OSAL多任务资源分配机制

    转自深入浅出Z-Stack 2006 OSAL多任务资源分配机制 一.概述 OSAL (Operating System Abstraction Layer),翻译为"操作系统抽象层&quo ...

  3. zigbee智能家居基础扫盲

    zigbee Zigbee是基于IEEE802.15.4标准的低功耗个域网协议.根据这个协议规定的技术是一种短距离.低功耗的无线通信技术.这一名称来源于蜜蜂的八字舞,由于蜜蜂(bee)是靠飞翔和&qu ...

  4. linux使用ps1设置命令行提示符

    要自定义命令行提示,需要ps1来设置.完成自定义需要以下几个步骤: 1.编辑~/.bashrc文件 vi ~/.bashrc 2.在.bashrc文件中添加以下一行自定义内容 export PS1=& ...

  5. eMMC尺寸

    eMMC Physical Specifications主要有四种结构,pin角定义及功能上基本一致,主要是看应用平台的需求: AA:12mm*16mm 169Pin  AB:12mm*18mm 16 ...

  6. [OJ] Matrix Zigzag Traversal

    LintCode #46. Matrix Zigzag Traversal (Easy) class Solution { public: vector<int> printZMatrix ...

  7. Leetcode解题思想总结篇:双指针

    Leetcode解题思想总结篇:双指针 1概念 双指针:快慢指针. 快指针在每一步走的步长要比慢指针一步走的步长要多.快指针通常的步速是慢指针的2倍. 在循环中的指针移动通常为: faster = f ...

  8. Eclipse中添加android sdk javadoc和source

    在 javadoc location path中添加file:/D:/Android_SDK/sdk/docs/reference/   在 source attachment中添加为 Externa ...

  9. bzoj1486

    这里学了一个新知识叫分数规划这道题目是求∑w[i]/S最小首先二分答案k,然后如果某个环∑w[i]/S<=k即∑w[i]<=k*S-->∑w[i]-k*S<=0--->∑ ...

  10. [ZOJ 3631] Watashi's BG

    Watashi's BG Time Limit: 3 Seconds      Memory Limit: 65536 KB Watashi is the couch of ZJU-ICPC Team ...