• 博客园logo
  • 会员
  • 周边
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • YouClaw
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
Allserver
Animation(BeiJing)Cyber-Tech Co.,Ltd.
博客园    首页    新随笔    联系   管理     

解决oracleSession被锁死的时候

当oracleSession被锁死的时候

 

经常出现一个问题,oracle的某张表突然无法更新了,无论是通过pl/sql Developer 还是通过sqlplus都无法更新,执行update语句或者执行select * from table_name for update 都一样,一直处于执行状态,无法完成,这时候我就猜想是不是session被锁死了呢?带着这个问题,我们写一条SQL语句:

 

1

--锁表查询SQL

?

1

2

3

4

SELECT object_name, machine, s.sid, s.serial#

FROM gv$locked_object l, dba_objects o, gv$session s

WHERE l.object_id = o.object_id

AND l.session_id = s.sid;

 

执行结果如下:

                       

可以看到这一条数据,也就是说,存在那么一个表被锁死了,这时候呢,我们也确认了,之前无法执行update

的这张表确实是因为被锁死了所以无法完成更新操作.<喎�"http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHA+yOe6zsrNt8XE2D+8zND41rTQ0NK7zPVTUWwg0+++5Do8L3A+CjxwPjwvcD4KPHByZSBjbGFzcz0=

"brush:sql;">ALTER system kill session '601, 802';

 

可以看到601 和802是查询到SID 和Serial ,格式为:alter system kill session "sid, serial#'; 执行完成之后:

 

没有了被锁死的session了,这时候再去执行我们的表更新操作,可以看到,更新已经没有问题了.

 

posted @ 2014-11-29 16:04  Allserver  阅读(276)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2026
浙公网安备 33010602011771号 浙ICP备2021040463号-3