我有一个在Oracle中运行的查询,可能会也可能不会挂起.它已经运行了大约10个小时,但根据我加载的数据量可能并非不合理.
我在gv $ session中查看会话,并想知道是否有一种方法可以转换该信息,看看是否有任何活动正在进行,或者查询是否等待锁定或其他方式挂起.
我已经在这里阅读了这个视图的文档.我主要是寻找那些在Oracle中调试这些类型问题的人的技巧.
谢谢!
在gv$session,该event列会告诉您会话当前正在等待的等待事件.如果你的会话正在等待另一个会话所持有的某种锁定,那么event会告诉你(例如,如果你排队等待锁定另一个会话持有的行,它将是"enq:TX - 行锁争用")和blocking_instance和blocking_session将与锁定的保持器的实例和会话ID进行填充.您还可以查看seconds_in_wait(if wait_time=0)以确定会话在当前等待事件中花费的秒数.这至少应该告诉你你的会话目前是否"陷入困境",但它并没有告诉你你的查询是否真的要完成 - 如果计划不好,你完全有可能"好"等待事件,如等待磁盘I/O,表明会话正在做某事,但查询永远不会真正完成.
根据一些进一步的研究和 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;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
55420 次 |
| 最近记录: |