oracleORA-00031:...
今天碰到⼀个问题,有⼀张表不能操作,很可能是被锁了,⾸先想到的是kill session,于是执⾏了下列的脚本到是哪个session有问题:
查看表是否被锁
SELECT /*+ rule*/
a.sid,
linux系统安装oracle11g
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进程的⽅式去杀掉进程。