oracle ORA-00031:session marked for kill(标记要终止的会话)
今天碰到一个问题,有一张表不能操作,很可能是被锁了,首先想到的是kill session,于是执行了下列的脚本找到是哪个session有问题: 查看表是否被锁 根据上面查询出的sid,找出对应的serial#: 发现有一个会话有锁sid 197,serial# 17,于是执行alter system kill session ‘197,17';大概等了30s中,pl/sql developer报出一个错误:ora-00031:标记要终止的会话。 解决方法:查出session的spidselect spid,osuser,s.program from v$session s,v$process p where s.paddr = p.addr and s.sid =197; 1. 在linux上, kill -9 12345 下面是补充:oracle中编译一个包的时候发现,只要一编译就卡死了,后来使用《oracle查询、Kill锁资源的SQL语句》方法查锁的时候发现包中用到的一些资源一直处于死锁状态。后来通过alter system kill session的方法去解锁,却发现出现如下图1所示的问题: ORA-00031:标记要终止的会话 后来通过连接上oracle数据库所在的系统,然后kill掉进程解决,方法如下: (1)查询被锁资源的sid、serial#: (2)利用上面的SQL查询出sid和serial#以后,利用下面SQL去kill session: -- 如有记录则表示lock,记录下SID和serial#,将记录下的SID和serial#替换下面的738,1429,即可接触lock。 (3)如果上面的kill session报如上图1的错误,那么再用下面的SQL去查处session对应的spid: (4)连上oracle数据库所在的系统(我这里是Linux系统),记录下上面查到的spid(假设这里查到的是1133),然后使用下面语句来kill掉进程: kill -9 1133 等待一会,等进程kill成功以后,再去查锁即可发现资源已经被释放。如果oracle安装在Windows系统上,请使用Windows系统的kill进程的方式去杀掉进程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |