婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > oracle ORA-00031:session marked for kill(標記要終止的會話)解決方法

oracle ORA-00031:session marked for kill(標記要終止的會話)解決方法

熱門標簽:開發外呼系統 哈爾濱電話機器人銷售招聘 慧營銷crm外呼系統丹丹 圖吧網站地圖標注 百度地圖標注途經點 山東crm外呼系統軟件 哪個400外呼系統好 地圖標注養老院 愛客外呼系統怎么樣

今天碰到一個問題,有一張表不能操作,很可能是被鎖了,首先想到的是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中查看引起Session阻塞的2個腳本分享
  • Oracle中的Connect/session和process的區別及關系介紹
  • ORACLE 如何查詢被鎖定表及如何解鎖釋放session
  • 對于oracle對session進行跟蹤的分析

標簽:承德 甘肅 開封 固原 青島 和田 武漢 周口

巨人網絡通訊聲明:本文標題《oracle ORA-00031:session marked for kill(標記要終止的會話)解決方法》,本文關鍵詞  oracle,ORA-00031,session,marked,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《oracle ORA-00031:session marked for kill(標記要終止的會話)解決方法》相關的同類信息!
  • 本頁收集關于oracle ORA-00031:session marked for kill(標記要終止的會話)解決方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 汶上县| 桓仁| 司法| 手游| 肥城市| 惠东县| 宝清县| 永丰县| 漳浦县| 丹寨县| 新乡县| 定安县| 兰考县| 上饶县| 基隆市| 牙克石市| 海兴县| 灵丘县| 瑞金市| 芮城县| 五河县| 互助| 石阡县| 虞城县| 正宁县| 大邑县| 闻喜县| 新化县| 龙门县| 鄂托克前旗| 阿坝县| 大同市| 浦东新区| 安丘市| 嘉禾县| 嘉黎县| 噶尔县| 左贡县| 江阴市| 进贤县| 西吉县|