此处以enq: TX - row lock contention等待时间为例。

查看snap_id对应时间

select to_char(s.startup_time,'dd Mon "at" HH24:mi:ss') instart_fmt

, di.instance_name inst_name

, di.db_name db_name

, s.snap_id snap_id

, to_char(s.end_interval_time,'dd Mon YYYY HH24:mi') snapdat

, s.snap_level lvl

from dba_hist_snapshot s

, dba_hist_database_instance di

where di.dbid = s.dbid

and di.instance_number = s.instance_number

and di.startup_time = s.startup_time

order by db_name, instance_name, snap_id;

如果在此回话发生在awr快照信息默认的保存天数以内。

可以通过如下sql查询到相关的session信息。

select * from DBA_HIST_ACTIVE_SESS_HISTORY where event like '%enq: TX - row lock contention%'

select * from dba_hist_active_sess_history WHERE event like 'enq: TX - row lock contention%' order by SAMPLE_TIME DESC

DBA_HIST_ACTIVE_SESS_HISTORY 中的blocking_session字段关联DBA_HIST_ACTIVE_SESS_HISTORY中的session_id找到对应的sql_id从而得到回话信息。

可以通过如下查询直接获取信息:

select t.instance_number,

t.sample_time,

lpad('-', 2 * (level - 1), '-') || t.client_id,

t.session_id,

t.blocking_session,

t.session_serial#,

t.sql_id,

t.event,

t.session_state,

level,

connect_by_isleaf,

connect_by_iscycle

from dba_hist_active_sess_history  t

where snap_id between 36878 and 36879

start with blocking_session is not null

and event like 'enq: TX - row lock contention%'

connect by nocycle sample_time = prior sample_time

and session_id = prior blocking_session

and session_serial# = prior blocking_session_serial#

其中blocking session为正在阻塞该回话的session

实战案例:

查看等待事件为行锁的session

select a.snap_id,

a.sql_id,

a.session_id,

a.session_serial#,

a.blocking_session,

a.blocking_session_serial#,

a.blocking_session_status

from DBA_HIST_ACTIVE_SESS_HISTORY a

where event like '%enq: TX - row lock contention%'

and snap_id between 20399 and 20400

编写子查询,查看阻塞回话,并统计阻塞次数

select a.blocking_session,

a.blocking_session_serial#,

count(a.blocking_session)

from DBA_HIST_ACTIVE_SESS_HISTORY a

where event like '%enq: TX - row lock contention%'

and snap_id between 20399 and 20400

group by a.blocking_session, a.blocking_session_serial#

order by 3 desc

查看阻塞回话的sql_id和被阻塞的sql_id,条件为阻塞大于19次的

select distinct b.sql_id,c.blocked_sql_id

from DBA_HIST_ACTIVE_SESS_HISTORY b,

(select a.sql_id as blocked_sql_id,

a.blocking_session,

a.blocking_session_serial#,

count(a.blocking_session)

from DBA_HIST_ACTIVE_SESS_HISTORY a

where event like '%enq: TX - row lock contention%'

and snap_id between 20399 and 20400

group by a.blocking_session, a.blocking_session_serial#,a.sql_id

having count(a.blocking_session) > 19

order by 3 desc) c

where b.session_id = c.blocking_session

and b.session_serial# = c.blocking_session_serial#

and b.snap_id between 20399 and 20400

动态性能视图注释:

V$ACTIVE_SESSION_HISTORY displays sampled session activity in the database. It contains snapshots of active database sessions taken once a second. A database session is considered active if it was on the CPU or was waiting for an event that didn't belong to the Idle wait class. Refer to the V$EVENT_NAME view for more information on wait classes.

这个视图三思老师的博客里将的比较清楚:

http://blog.itpub.net/7607759/viewspace-617178

This view contains one row for each active session per sample and returns the latest session sample rows first. A majority of the columns describing the session in the active session history are present in the V$SESSION view.

DBA_HIST_ACTIVE_SESS_HISTORY displays the history of the contents of the in-memory active session history of recent system activity. This view contains snapshots of V$ACTIVE_SESSION_HISTORY. See "V$ACTIVE_SESSION_HISTORY" for further interpretation details for many of these columns (except SNAP_ID, DBID, and INSTANCE_NUMBER).

查看历史会话等待事件对应的session信息的更多相关文章

  1. 【参考】查找Oracle最高的几个等待事件以及锁的信息

    1.通过操作系统的命令找到系统资源的bottleneck,如:CPU, Memory, I/O, Network  同时主要关注IOWait, PI/PO, Memory的使用情况 2.通过查询v$s ...

  2. DBA常用SQL之会话与等待事件

    SELECT * FROM V$SESSION WHERE USERNAME IS NOT NULL AND STATUS = 'ACTIVE' ORDER BY LOGON_TIME, SID; 1 ...

  3. 查看造成等待事件的具体SQL语句

    先查看存在的等待事件:col event for a40col WAIT_CLASS format a20select sid,WAIT_CLASS,event,p1,p2,p3,WAIT_TIME, ...

  4. Oracle中常见的33个等待事件小结

    在Oracle 10g中的等待事件有872个,11g中等待事件1116个. 我们可以通过v$event_name 视图来查看等待事件的相关信息     一. 等待事件的相关知识 1.1 等待事件主要可 ...

  5. ORACLE 常见等待事件

    一. 等待事件的相关知识 1.1 等待事件主要可以分为两类,即空闲(IDLE)等待事件和非空闲(NON-IDLE)等待事件.1). 空闲等待事件指ORACLE正等待某种工作,在诊断和优化数据库的时候, ...

  6. 全面解析Oracle等待事件的分类、发现及优化

    一.等待事件由来 大家可能有些奇怪,为什么说等待事件,先谈到了指标体系.其实,正是因为指标体系的发展,才导致等待事件的引入.总结一下,Oracle的指标体系,大致经历了下面三个阶段: · 以命中率为主 ...

  7. Oracle等待事件之等待事件详解

    一. 等待事件的相关知识:1.1 等待事件主要可以分为两类:即空闲(IDLE)等待事件和非空闲(NON-IDLE)等待事件.1). 空闲等待事件指ORACLE正等待某种工作,在诊断和优化数据库的时候, ...

  8. 【Oracle】等待事件详细内容

    一.等待事件的相关知识 1.1 等待事件主要可以分为两类,即空闲(IDLE)等待事件和非空闲(NON-IDLE)等待事件.1). 空闲等待事件指ORACLE正等待某种工作,在诊断和优化数据库的时候,不 ...

  9. Oracle 常见的33个等待事件

    一. 等待事件的相关知识: 1.1 等待事件主要可以分为两类,即空闲(IDLE)等待事件和非空闲(NON-IDLE)等待事件. 1). 空闲等待事件指Oracle正等待某种工作,在诊断和优化数据库的时 ...

随机推荐

  1. WPF 窗口去除顶部边框(正宗无边框)

    最近在做一个大屏展示视频图片的项目,功能并不复杂,半天的工作量吧,一开始同事采用的Unity3D进行开发,但是里面要播放4K视频,Unity 的短板就是视频的播放了,今晚就要交付了,我一早就来公司,决 ...

  2. docker镜像的使用及相关

    参考网站docker中文网:http://www.docker.org.cn/book/docker/docker-push-image-13.html 1.搜索容器: docker search t ...

  3. AC的故事大结局山寨版(下)

    AC的故事大结局山寨版(下) TimeLimit:2000MS  MemoryLimit:128MB 64-bit integer IO format:%lld   Problem Descripti ...

  4. Java框架中Struts和Struts2框架的区别

    struts1 与 struts2 的区别:1.都是 MVC 的 WEB 框架,2 struts1的老牌框架,应用很广泛,有很好的群众基础,使用它开发风险很小,成本更低!struts2虽然基于这个框架 ...

  5. sql语句的删除

    SQL中delete * from 和 delete from 有什么区别? 在SQL Server中两者没有区别,但在Oracle和MySQL的SQL语句中,delete * from是不标准的语法 ...

  6. 一次ES故障排查过程

    作者:莫那鲁道 原文:http://thinkinjava.cn/#blog 某天晚上,某环境 ES 出现阻塞, 运行缓慢.于是开始排查问题的过程. 开始 思路:现象是阻塞,通常是 CPU 彪高,导致 ...

  7. css中的宽度

    浏览器通过CSS对元素的盒子模型的描述进行页面渲染的.因此,元素的宽度受到父元素.css描述的影响. 通常,元素的宽度是指盒子模型中content-box所占用的宽度.也就是说,默认box-sizin ...

  8. ios 运行时特征,动态改变控件字体大小

    需求:ex: 在不同尺寸的iPhone上面显示的字体大小不一样 https://github.com/rentzsch/jrswizzle #import <UIKit/UIKit.h> ...

  9. 一起学爬虫——PyQuery常用用法总结

    什么是PyQuery PyQuery是一个类似于jQuery的解析网页工具,使用lxml操作xml和html文档,它的语法和jQuery很像.和XPATH,Beautiful Soup比起来,PyQu ...

  10. Android 调用 .NET WebService

    1.下载并导入jar工具类包 打开下载界面http://simpligility.github.io/ksoap2-android/getting-started.html ,拉倒最下 2.Copy ...