加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 15:11:51 所属栏目:百科 来源:网络整理
导读:我有一个在Oracle中运行的查询,可能会也可能不会挂起.它已经运行了大约10个小时,但根据我加载的数据量可能并非不合理. 我在gv $session中查看会话,并想知道是否有一种方法可以转换该信息,看看是否有任何活动正在进行,或者查询是否等待锁定或其他方式挂起. 我
我有一个在Oracle中运行的查询,可能会也可能不会挂起.它已经运行了大约10个小时,但根据我加载的数据量可能并非不合理.

我在gv $session中查看会话,并想知道是否有一种方法可以转换该信息,看看是否有任何活动正在进行,或者查询是否等待锁定或其他方式挂起.

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

谢谢!

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读