PL/SQL 锁住的解决方法

  

在用PL/SQL  Developer  操作Oracle 数据库的过程中,台式机电脑突然重启了。重启后,当时觉得也没什么。但当我清空某一个表的数据时,却提示我该表被其他用户锁住了。我把和我在一起开发的同事问了一遍,他们都说没锁住任何表,此时我郁闷了。找了很久才发现是,因为突然重启电脑,这个软件自动把当时正在使用的表锁住了。在Tools->Sessions,此时用户可以看到PL/SQL 正在运行的进程。选中某个进程,再在该软件下方切换到Lock选项卡;如果是某个进程锁住了某张表,Lock选项卡中会列出来,你选中进程,点击右键Kill掉该进程,表被锁住的问题就解决啦。

PL/SQL <wbr> <wbr>Developer <wbr> <wbr>锁住表的解决方法

 

方法二

1、查看数据库锁,诊断锁的来源及类型:

select object_id,session_id,locked_mode from v$locked_object;

或者用以下命令: 

select b.owner,b.object_name,l.session_id,l.locked_mode from v$locked_object l, dba_objects b where b.object_id=l.object_id 

2、找出数据库的serial#,以备杀死:

select t2.username,t2.sid,t2.serial#,t2.logon_time from v$locked_object t1,v$session t2 where t1.session_id=t2.sid order by t2.logon_time; 

3、杀死该session:   

alter system kill session 'sid,serial#'

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值