设为首页 加入收藏

TOP

当oracleSession被锁死的时候
2014-11-23 17:56:22 来源: 作者: 【 】 浏览:56
Tags:oracleSession 锁死 时候

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

 
--锁表查询SQL
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了,这时候再去执行我们的表更新操作,可以看到,更新已经没有问题了.

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Oraclenotexists的等价写法 下一篇Oracleupdate+with的使用场景

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: