(未看)ORACLE物理读和逻辑读(SET AUTOTRACE ON 部分参数解释)[逻辑IO只有逻辑读,没有逻辑写]
逻辑IO只有逻辑读,没有逻辑写
ORACLE物理读和逻辑读(SET AUTOTRACE ON 部分参数解释)
set autotrace 产生部分信息解读的官方文档基本的定义为如下:
recursive calls: Number of recursive calls generated at both the user and system level.
[url=]Oracle[/url]
maintains tables used for internal processing. When Oracle needs to make a change to
these tables, it internally generates an internal [url=]SQL[/url] statement, which in turn generates a
recursive call.
DB block gets: The number of accesses to the current image of a block
当前模式块意思就是在操作中正好提取的块数目,而不是在一致性读的情况下而产生的块数。正常的情况下,一个查询提取的块是在查询开始的那个时间点上存在的数据块,当前块是在这个时刻存在的数据块,
而不是在这个时间点之前或者之后的数据块数目。
Consistent gets: The number of accesses to a read-consistent image of a block(单位:块次,即读每块的次数)
数据请求总数在回滚段Buffer中的数据一致性读所需要的数据块
Physical reads: The number of blocks read from disk(单位:块次,即读每块的次数)
逻辑读是指读内存,物理读是指读磁盘,在set autotrace on下,他们关系如下:
LOGICAL IO = db_block_gets + consistent_gets
PHYSICAL IO = physical_reads
由此,自然也就得出了cache命中率的公式:
Hit Ratio = (db block gets + consistent gets - physical reads) / (db block gets + consistent gets)
或者Hit Ratio = 1 – (physical reads/(db block gets + consistent gets))
逻辑读的理解(摘自晶晶小妹文章):
我们都知道,数据块是oracle最基本的读写单位,但用户所需要的数据,并不是整个块,而是块中的行,或列.当用户发出SQL语句时,此语句被解析执行完毕,就开始了数据的抓取阶段,在此阶段,服务器进程会先将行所在的数据块从数据文件中读入buffer cache,这个过程叫做物理读.物理读,每读取一个块,就算一次物理读.当块被送进buffer cache后,并不能立即将块传给用户,因为用户所需要的并不整个块,而是块中的行.从buffer cache的块中读取行的过程,就是逻辑读.
但Oracle并不会在一次逻辑读中,读块中所有的行,而是根据用户的设定,一次读一部分行。为了完成一次逻辑读,服务器进程先要在hash表中查找块所在的cache buffer 链.找到之后,需要在这个链上加一个cache buffer chains 闩,加闩成功之后,就在这个链中寻找指定的块,并在块上加一个pin锁.并释放cache buffer chains闩.然后就可以访问块中的行了.服务器进程不会将块中所有满足条件的行一次取出,而是根据你的抓取命令,每次取一定数量的行.这些行取出之后,会经由PGA传给客户端用户.行一旦从buffer cache中取出,会话要释放掉在块上所加的PIN.本次逻辑读就算结束.如果还要再抓取块中剩余的行,服务器进程要再次申请获得cache bufffer链闩.再次在块上加PIN.这就算是另外一次逻辑读咯.也就是说,服务器进程每申请一次cache buffer链闩,就是一次逻辑读.而每次逻辑读所读取的行的数量,可以在抓取命令中进行设置.
逻辑读和Cache buffer chains闩关系密切,TOM曾有文章提到,进程每申请一次Cache buffer chains闩,就是一次逻辑读。但是,逻辑读并不等同于Cache buffer chains闩,每次逻辑读,在9i中至少需要获得两Cache buffer chains闩。逻辑读是指在Hash表中定位块的这个过程。
如果一次Fetch,访问了N个块,就是N个逻辑读。如果一个块中的行,花费N次Fetch才抓取完,也是N个逻辑读。
几个问题:
1. 每次逻辑读所读取的行的数量默认是几条?
2. 如何在抓取命令中设置?
3. 只对当前的session有效吧?
4. 如果采用普通的fetch游标(不用bulk collect),那么每次逻辑读所读取的行的数量是?
问题1:set arraysize 可以设置系统当前的值,查看的语句是:show arraysize,默认值15,有效值1到5000
补充:Arraysize by default is 15 in sqlplus,10 in JDBC,2 in pro*c,1 in OCI
(参考tomkyte:http://asktom.oracle.com/pls/ask ... ION_ID:880343948514)
问题2:fetch 游标 bulk collect into 变量limit N;
问题3. 只针对当前会话有效.
问题4. 普通的fetch,一次抓取一行,每读一行在不考虑行迁移行链接的情况下,是一个逻辑读.
在sqlplus下利用命令set autotrace on会产生一些统计信息,其中包括Consistent gets,
从官网文档中看不出到底这个值是如何产生的,
如果对一个表进行全表扫描并取出所有记录(select * from table),可以把算法写为:
Consistent gets=rows/arraysize + N (N为读表时在cache中占用的总的块数,参考asktom,ORACLE8i)
或者Consistent gets=rows/arraysize + N + recursive calls(自己[url=]实验[/url]结果,ORACLE10g)
实验如下:
SQL> drop table test; Table dropped. Elapsed: 00:00:00.26 SQL> create table test( a int); Table created. Elapsed: 00:00:00.04 SQL> begin 2 for i in 1..10000 loop 3 insert into test values (i); 4 end loop; 5 end; 6 / PL/SQL procedure successfully completed. Elapsed: 00:00:01.68 --并未执行commit SQL> set autotrace traceonly SQL> select count(0) from test; Elapsed: 00:00:00.01 Execution Plan ---------------------------------------------------------- Plan hash value: 3467505462 ------------------------------------------------------------------- | Id | Operation | Name | Rows | Cost (%CPU)| Time | ------------------------------------------------------------------- | 0 | SELECT STATEMENT | | 1 | 6 (0)| 00:00:01 | | 1 | SORT AGGREGATE | | 1 | | | | 2 | TABLE ACCESS FULL| TEST | 10000 | 6 (0)| 00:00:01 | ------------------------------------------------------------------- Note ----- - dynamic sampling used for this statement Statistics Statistics Statistics SQL> set arraysize 20 --设置arraysize为20时, Statistics
|
疑问:Arraysize by default is 15 in sqlplus,10 in JDBC,2 in pro*c,1 in OCI 未经过实验,另外,在这相应的环境下如何修改arraysize?
(未看)ORACLE物理读和逻辑读(SET AUTOTRACE ON 部分参数解释)[逻辑IO只有逻辑读,没有逻辑写]相关推荐
- Oracle 物理读 逻辑读 一致性读 当前模式读总结浅析
Oracle 物理读 逻辑读 一致性读 当前模式读总结浅析 在ORACLE数据库中有物理读(Physical Reads).逻辑读(Logical Reads).一致性读(Consistant Get ...
- Oracle物理存储结构--文件
原文地址:[基础]Oracle物理存储结构--文件作者:诗意方式 1 数据文件 3.查询数据文件参数 要将数据文件置为脱机状态,可以通过下列语句实现,如将SCOTT对象的数据文件置为脱机状态: SQL ...
- Oracle物理的体系结构
体系结构图的学习: 老余服装店的故事 结构图: SQL查询语句 SGA 共享池shared pool 数据缓存区Buffer cache PGA 进程 SQL更新语句 SGA: 日志缓存区 日志文件 ...
- 面试题: !=!=未看12 略多 sql语句练习 非常 有用
JAVA面试总结 2015年03月25日 16:53:40 阅读数:4306 刚才看到的,先转载过来,没准以后用到-- 面试总结 2013年8月6日: 问题2:Hibernate的核心接口有哪些? ...
- 青年大学习未看人员名单查询(JAVA)
青年大学习未看人员名单查询 前言 代码演示 compare1 compare2 compare3 文件目录 后记 Compare4(加了一个查询重复观看人物的功能) 前言 感觉自己给个智障似的,(ll ...
- 读的, 且经过美化, 能在所有 JavaScript 环境中运行, 并且应该和对应手写的 JavaScript 一样快或者更快.
目录 试一试 CoffeeScript 代码和注释 CoffeeScript 是一门编译到 JavaScript 的小巧语言. 在 Java 般笨拙的外表下, JavaScript 其实有着一颗华丽的 ...
- 未找到 Oracle 客户端和网络组件问题
最近一直在研究如何解决"未找到 Oracle 客户端和网络组件.这些组件是由 Oracle 公司提供的,是 Oracle 8i 版 (或更高) 客户软件安装的一部分..."的问题, ...
- 开机预读快还是不预读快_【采纳后追加100悬赏!】恢复开机预读后为什么变成了延迟预读?...
简单描述:开机进入桌面后,总要等到任务管理器显示的"开机时间"第8分钟才开始预读![不是不预读,而是延迟预读!]详细描述:以前开机后立马就开始预读(开机后一两分钟),之后所... ...
- oracle 12 ORA-01262,oracle物理dg安装:方法二
本文记录了物理dg的第二种安装方法,使用rman duplicate from active database,不需要做备份文件. 准备工作: 1.两台虚拟机,主机名:n1, n2,操作系统:cent ...
最新文章
- 解决vuex页面刷新导致数据丢失问题
- Java:Java的输入类Scanner
- Apache Hadoop YARN – NodeManager--转载
- boost::sort模块实现测试并行稳定排序
- ComponentName的意思
- get和post 两种基本请求方式的区别
- 王彪-20162321《程序设计与数据结构2nd》-第十一周学习总结与实验报告
- JAVA获取服务器路径的方法
- python字符串相加_谁说python字符串相加效率低
- 一个比较全介绍UltraGrid的博客
- python 检查域名是否可以访问_糖尿病人是否都要做喝糖水的检查?结果可以说明胰岛功能水平吗?...
- CVPR2022 | 利用域自适应思想,北大、字节跳动提出新型弱监督物体定位框架
- 图灵 计算机 ppt,人工智能导论(ppt 155页)
- 什么是外汇EA?外汇EA有什么风险?
- 泛微OA主表与明细表的js操作
- 用keytool生成证书
- 污水处理设备:生物技术如何处理畜禽养殖污水?
- 下一代图像压缩格式科普---HEIF 与AVIF格式
- Latex——数学符号大全
- 计算机应用基础学习网站,《计算机应用基础》学习手册.pdf