度量快速开发平台-专业、快速的软件定制快开平台
标题: ORA-00031:标记要终止的会话 [打印本页]
作者: 万望 时间: 2020-4-1 21:18
标题: ORA-00031:标记要终止的会话
oracle中编译一个包的时候发现,只要一编译就卡死了,后来使用《oracle查询、Kill锁资源的SQL语句》方法查锁的时候发现包中用到的一些资源一直处于死锁状态。后来通过alter system kill session的方法去解锁,却发现出现如下图1所示的问题:
图1:ORA-00031:标记要终止的会话
后来通过连接上oracle数据库所在的系统,然后kill掉进程解决,方法如下:
(1)查询被锁资源的sid、serial#:
- SELECT s.sid,
- s.serial#,
- v.*,
- ao.*
- FROM v$locked_object v,
- all_objects ao,
- v$session s
- WHERE v.object_id = ao.object_id
- AND s.sid = v.session_id;
复制代码(2)利用上面的SQL查询出sid和serial#以后,利用下面SQL去kill session:
- -- 如有记录则表示lock,记录下SID和serial#,将记录下的SID和serial#替换下面的738,1429,即可接触lock。
- ALTER SYSTEM KILL SESSION '738,1429';
复制代码(3)如果上面的kill session报如上图1的错误,那么再用下面的SQL去查处session对应的spid:
- SELECT p.spid,
- s.osuser,
- s.program
- FROM v$session s,
- v$process p
- WHERE s.paddr = p.addr
- AND s.sid = 37; -- 替换成相应的session_id
复制代码(4)连上oracle数据库所在的系统(我这里是Linux系统),记录下上面查到的spid(假设这里查到的是1133),然后使用下面语句来kill掉进程:
等待一会,等进程kill成功以后,再去查锁即可发现资源已经被释放。如果oracle安装在Windows系统上,请使用Windows系统的kill进程的方式去杀掉进程。
作者: 陈晓龙 时间: 2020-4-2 19:23
欢迎光临 度量快速开发平台-专业、快速的软件定制快开平台 (http://p.delit.cn/) |
Powered by Discuz! X3.2 |