首頁  >  文章  >  資料庫  >  oracle鎖表的原因

oracle鎖表的原因

hzc
hzc原創
2020-06-09 13:27:114080瀏覽

oracle鎖表的原因

oracle鎖定表的原因:

#1. 檢視目前系統中鎖定表情況 

select * from v$locked_object

可以透過查詢

v$locked_object拿到sidobjectid

然後用sidv$session鏈表格查詢是哪裡鎖的表,

用v$session中的objectid欄位和dba_objects id欄位關聯,

查詢詳細的鎖定表情況。

查詢SQL如下: 

select sess.sid, 
       sess.serial#, 
       lo.oracle_username, 
       lo.os_user_name, 
       ao.object_name, 
       lo.locked_mode 
from v$locked_object lo, dba_objects ao, v$session sess, v$process p 
where ao.object_id = lo.object_id and lo.session_id = sess.sid;

查詢是什麼SQL造成了鎖定表的原因,SQL如下: 

select l.session_id sid, 
       s.serial#, 
       l.locked_mode, 
       l.oracle_username, 
       s.user#, 
       l.os_user_name, 
       s.machine, 
       s.terminal, 
       a.sql_text, 
       a.action 
  from v$sqlarea a, v$session s, v$locked_object l 
where l.session_id = s.sid and s.prev_sql_addr = a.address 
order by sid, s.serial#;

2. ORACLE解鎖的方法 

alter system kill session 'sid,serial#';

spid  鎖定的進程號碼

serial# v$session 这个视图中取出来的

推薦教學:《Oracle教學

#

以上是oracle鎖表的原因的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:怎麼安裝oracle下一篇:怎麼安裝oracle