日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發布時間:2023/12/15 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle+标记要,oracle ORA-00031:session marked for kill(标记要终止的会话)解决方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

今天碰到一個問題,有一張表不能操作,很可能是被鎖了,首先想到的是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+标记要,oracle ORA-00031:session marked for kill(标记要终止的会话)解决方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。