使用gv $ session来判断查询是否挂起

时间:2012-04-27 14:14:52

标签: oracle oracle10g

我在Oracle中运行了一个查询,可能会也可能不会挂起。它已经运行了大约10个小时,但根据我加载的数据量可能并非不合理。

我正在查看gv $ session中的会话,并想知道是否有办法翻译该信息,看看是否有任何活动正在进行,或者查询是否等待锁定或其他方式挂起。

我已经阅读了此视图的文档here。我主要是寻找在Oracle中调试这些类型问题的人的技巧。

谢谢!

3 个答案:

答案 0 :(得分:8)

gv$session中,event列会告诉您会话当前正在等待的等待事件。如果你的会话正在等待另一个会话所持有的某种锁定,event会告诉你(例如,如果你排队等待锁定一行,它将是“enq:TX - 行锁争用”由另一个会话持有)并且blocking_instanceblocking_session将填充锁的持有者的实例和会话ID。您还可以查看seconds_in_wait(如果wait_time=0)以确定会话在当前等待事件中花费的秒数。这至少应该告诉你你的会话目前是否“陷入困境”,但它并没有告诉你你的查询是否真的要完成 - 如果有一个糟糕的计划,你完全有可能“好”等待事件,比如等待磁盘I / O,表明会话正在做某事,但查询永远不会真正完成。

答案 1 :(得分:4)

根据一些进一步的研究和Ollie的评论,我提出了这些有助于调试问题的查询:

select s.sid, 
       s.username,
       s.machine,
       s.osuser, 
       cpu_time,
       (elapsed_time/1000000)/60 as minutes,
       sql_text
from gv$sqlarea a, gv$session s
where s.sql_id = a.sql_id
and s.machine like '####';


select lo.*, 
       a.sql_text
from gv$sqlarea a, gv$session_longops lo
where lo.sql_id = a.sql_id
and lo.sid = ####
order by lo.start_time;

答案 2 :(得分:0)

这将有助于检查当前正在运行的会话

select a.SID, a.SERIAL#, c.OBJECT_NAME 
from v$session a, v$locked_object b, user_objects c
where a.SID=b.SESSION_ID and b.OBJECT_ID=c.OBJECT_ID