read by other session等待事件

read by other session发生的场景:

 当查询数据时,Oracle要把block从硬盘读到buffer cache中。如果有两个或更多session同时读取同一个block数据,第一个session会将block读取到buffer cache,由于block尚未完全读取到buffer cache,就导致其他session处于"read by other session"等待下。这个是oracle 10g从oracle 9i的"buffer busy waits"中分离出来的,也是一种热块现象。


read by other session等待事件有三个参数,属于User I/O类的等待 :

 SQL> select name,parameter1,parameter2,parameter3,wait_class from v$event_name where name = 'read by other session';

 NAME                           PARAMETER1           PARAMETER2           PARAMETER3           WAIT_CLASS

 ------------------------------ -------------------- -------------------- -------------------- -----------

 read by other session          file#                block#               class#               User I/O

 

 file#:要读取的数据块锁在数据文件的文件号

 block#:要读取的起始数据块号

 class#:块类型


可根据等待的file#、block#结合下面的sql获取热点块所在的segment:

SELECT OWNER, SEGMENT_NAME, SEGMENT_TYPE, TABLESPACE_NAME, A.PARTITION_NAME

FROM DBA_EXTENTS A

WHERE FILE_ID = &FILE_ID

AND &BLOCK_ID BETWEEN BLOCK_ID AND BLOCK_ID + BLOCKS – 1;


查询热点块对象:

SELECT *

FROM

(

 SELECT O.OWNER, O.OBJECT_NAME, O.OBJECT_TYPE, SUM(TCH) TOUCHTIME

 FROM X$BH B, DBA_OBJECTS O

 WHERE B.OBJ = O.DATA_OBJECT_ID

 AND B.TS# > 0

 GROUP BY O.OWNER, O.OBJECT_NAME, O.OBJECT_TYPE

 ORDER BY SUM(TCH) DESC

WHERE ROWNUM <= 10


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31544156/viewspace-2219653/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31544156/viewspace-2219653/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值