oracle ORA-00031:session marked for kill(标记要终止的会话)解决方法

所属分类: 数据库 / oracle 阅读数: 1248
收藏 0 赞 0 分享

今天碰到一个问题,有一张表不能操作,很可能是被锁了,首先想到的是kill session,于是执行了下列的脚本找到是哪个session有问题:

查看表是否被锁

SELECT /*+ rule*/
a.sid, b.owner, object_name, object_type
FROM v$lock a, all_objects b
WHERE TYPE = 'TM'
and a.id1 = b.object_id;

根据上面查询出的sid,找出对应的serial#:
SELECT sid,serial# FROM v$session WHERE sid = &sid;

发现有一个会话有锁sid 197,serial# 17,于是执行alter system kill session ‘197,17';大概等了30s中,pl/sql developer报出一个错误:ora-00031:标记要终止的会话。

解决方法:查出session的spid

select 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
2. 在windows上,C:\Documents and Settings\gg>orakill orcl 12345

orcl:表示要杀死的进程属于的实例名
12345:是要杀掉的线程号

ORA-00031: session marked for kill
Cause: The session specified in an ALTER SYSTEM KILL SESSION command cannot bekilled immediately (because it is rolling back or blocked on a networkoperation), but it has been marked for kill. This means it will be killed as soonas possible after its current uninterruptible operation is done.
Action: No action is required for the session to be killed, but further executionsof the ALTER SYSTEM KILL SESSION command on this session may cause the sessionto be killed sooner.

下面是补充:

oracle中编译一个包的时候发现,只要一编译就卡死了,后来使用《oracle查询、Kill锁资源的SQL语句》方法查锁的时候发现包中用到的一些资源一直处于死锁状态。后来通过alter system kill session的方法去解锁,却发现出现如下图1所示的问题:
ORA-00031:标记要终止的会话

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 -9 1133

等待一会,等进程kill成功以后,再去查锁即可发现资源已经被释放。如果oracle安装在Windows系统上,请使用Windows系统的kill进程的方式去杀掉进程。

更多精彩内容其他人还在看

Oracle 子程序参数模式,IN,OUT,NOCOPY

Oracle 子程序参数模式主要有IN,OUT,NOCOPY,IN和OUT可以组合,OUT和NOCOPY也可以组合使用.
收藏 0 赞 0 分享

Oracle 存储过程加密方法

Oracle 存储过程加密方法,需要的朋友可以参考下。
收藏 0 赞 0 分享

oracle 多个字符替换实现

CSDN上的一个网友,需要一个sql语句的解决方案需求是这样的求写oracle多个字符替换(有测试数据)
收藏 0 赞 0 分享

Oracle 存储过程教程

一个简单的oracle分页存储过程的实现和调用。在看了众多的分页存储过程以后发现都是针对sqlserver的,而没有oracle的,因此想写一个关于oracle的存储过程,因为我用到的数据库是oracle。
收藏 0 赞 0 分享

oracle 更改数据库名的方法

这两天一朋友问如何更改数据库名,于是做个测试,简单记录下,以便说明问题。
收藏 0 赞 0 分享

Oracle 分析函数RANK(),ROW_NUMBER(),LAG()等的使用方法

Oracle分析函数RANK(),ROW_NUMBER(),LAG()等的使用方法,需要的朋友可以参考下。
收藏 0 赞 0 分享

Oracle字符集修改查看方法

Oracle字符集修改查看方法,需要的朋友可以参考下。
收藏 0 赞 0 分享

一些实用的sql语句

一些实用的sql,需要的朋友可以参考下。
收藏 0 赞 0 分享

Oracle中sys和system的区别小结

SYS用户具有DBA权限,并且拥有SYS模式,只能通过SYSDBA登陆数据库。是Oracle数据库中权限最高的帐号 SYSTEM具有DBA权限。但没有SYSDBA权限。平常一般用该帐号管理数据库就可以了。
收藏 0 赞 0 分享

oracle 存储过程和触发器复制数据

oracle 存储过程和触发器复制数据的代码,需要的朋友可以参考下。
收藏 0 赞 0 分享
查看更多