亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

怎樣快速查出Oracle 數據庫中的鎖等待

2024-08-29 13:46:55
字體:
來源:轉載
供稿:網友
怎樣快速查出Oracle 數據庫中的鎖等待 ---- 在大型數據庫系統中,為了保證數據的一致性,在對數據庫中的數據進行操作時,系統會進行對數據相應的鎖定。 ---- 這些鎖定中有"只讀鎖"、"排它鎖","共享排它鎖"等多種類型,而且每種類型又有"行級鎖"(一次鎖住一條記錄),"頁級鎖"(一次鎖住一頁,即數據庫中存儲記錄的最小可分配單元),"表級鎖"(鎖住整個表)。 ---- 若為"行級排它鎖",則除被鎖住的該行外,該表中其它行均可被其它的用戶進行修改(Update)或刪除(delete)操作,若為"表級排它鎖",則所有其它用戶只能對該表進行查詢(select)操作,而無法對其中的任何記錄進行修改或刪除。當程序對所做的修改進行提交(commit)或回滾后(rollback)后,鎖住的資源便會得到釋放,從而答應其它用戶進行操作。 ---- 但是,有時,由于程序中的原因,鎖住資源后長時間未對其工作進行提交;或是由于用戶的原因,如調出需要修改的數據后,未及時修改并提交,而是放置于一旁;或是由于客戶服務器方式中客戶端出現"死機",而服務器端卻并未檢測到,從而造成鎖定的資源未被及時釋放,影響到其它用戶的操作。 ---- 因而,如何迅速地診斷出鎖住資源的用戶以及解決其鎖定便是數據庫治理員的一個挑戰。 ---- 由于數據庫應用系統越來越復雜, 一旦出現由于鎖資源未及時釋放的情況,便會引起對一相同表進行操作的大量用戶無法進行操作,從而影響到系統的使用。此時,DBA應盡量快地解決問題。但是,由于在Oracle 8.0.x 中執行"獲取正在等待鎖資源的用戶名"的查詢語句 select a.username, a.sid, a.serial#, b.id1
from v$session a, v$lock b
where a.lockwait = b.kaddr ---- 十分緩慢,(在 Oracle 7.3.4中執行很快),而且,執行"查找阻塞其它用戶的用戶進程"的查詢語句
select a.username, a.sid, a.serial#, b.id1
from v$session a, v$lock b
where b.id1 in
(select distinct e.id1
from v$session d, v$lock e
where d.lockwait = e.kaddr)
and a.sid = b.sid
and b.request = 0 ---- 執行得也十分緩慢。因而,往往只好通過將 v$session 中狀態為"inactive"(不活動)并且最后一次進行操作時間至當前已超過 20 分鐘以上(last_call_et>20*60 秒)的用戶進程清除,然后才使得問題得到解決。
---- 但是,這種方法實際上是"把嬰兒與臟水一起潑掉"。因為,有些用戶的進程盡管也為"inactive",并且也已有較長時間未活動,但是,那是由于他們處于鎖等待狀態。 ---- 因而,我想出了一個解決辦法。即通過將問題發生時的 v$lock,v$session視圖中的相關記錄保存于自己建立的表中,再對該表進行查詢,則速度大大提高,可以迅速發現問題。經實際使用,效果非常好。在接到用戶反映后,幾秒鐘即可查出由于鎖住資源而影響其它用戶的進程,并進行相應的處理。 ---- 首先,以 dba 身份(不一定為system)登錄入數據庫中,創建三個基本表:my_session,my_lock, my_sqltext,并在將會進行查詢的列上建立相應的索引。語句如下: rem 從 v$session 視圖中取出關心的字段,創建 my_session 表,并在查詢要用到的字段上創建索引,以加快查詢速度 drop table my_session;
create table my_session
as
select a.username, a.sid, a.serial#,
a.lockwait, a.machine,a.status,
a.last_call_et,a.sql_hash_value,a.PRogram
from v$session a
where 1=2 ; create unique index my_session_u1 on my_session(sid);
create index my_session_n2 on my_session(lockwait);
create index my_session_n3 on my_session(sql_hash_value); ---- rem 從 v$lock 視圖中取出字段,創建 my_lock 表,并在查詢要用到的字段上創建索引,以加快查詢速度
drop table my_lock;
create table my_lock
as
select id1, kaddr, sid, request,type
from v$lock
where 1=2; create index my_lock_n1 on my_lock(sid);
create index my_lock_n2 on my_lock(kaddr); ---- rem 從 v$sqltext 視圖中取出字段,創建 my_sqltext 表,并在查詢要用到的字段上創建索引,以加快查詢速度
drop table my_sqltext;
create table my_sqltext
as
select hash_value , sql_text
from v$sqltext
where 1=2;
create index my_sqltext_n1 on my_sqltext ( hash_value); ---- 然后,創建一個 SQL 腳本文件,以便需要時可從 SQL*Plus 中直接調用。其中,首先用 truncate table 表名命令將表中的記錄刪除。之所以用 truncate 命令,而不是用delete 命令,是因為delete 命令執行時,將會產生重演記錄,速度較慢,而且索引所占的空間并未真正釋放,若反復做 insert及delete,則索引所占的空間會不斷增長,查詢速度也會變慢。而 truncate命令不產生重演記錄,速度執行較delete快,而且索引空間被相應地釋放出來。刪除記錄后,再將三個視圖中的相關記錄插入自己創建的三個表中。最后,對其進行查詢,由于有索引,同時由于在插入時條件過濾后,記錄數相對來說較少,因而查詢速度很快,馬上可以看到其結果。
---- 此時,若發現該阻塞其它用戶進程的進程是正常操作中,則可通知該用戶對其進行提交,從而達到釋放鎖資源的目的;若為未正常操作,即,其狀態為"inactive",且其last_call_et已為較多長時間,則可執行以下語句將該進程進行清除,系統會自動對其進行回滾,從而釋放鎖住的資源。 alter system kill session 'sid, serial#';
---- SQL 腳本如下:
set echo off
set feedback off
prompt '刪除舊記錄.....'
truncate table my_session;
truncate table my_lock;
truncate table my_sqltext; prompt '獲取數據.....'
insert into my_session
select a.username, a.sid, a.serial#,
a.lockwait, a.machine,a.status,
a.last_call_et,a.sql_hash_value,a.program
from v$session a
where nvl(a.username,'NULL')< >'NULL; insert into my_lock
select id1, kaddr, sid, request,type
from v$lock; insert into my_sqltext
select hash_value , sql_text
from v$sqltext s, my_session m
where s.hash_value=m.sql_hash_value; column username format a10
column machine format a15
column last_call_et format 99999 heading "Seconds"
column sid format 9999 prompt "正在等待別人的用戶"
select a.sid, a.serial#,
a.machine,a.last_call_et, a.username, b.id1
from my_session a, my_lock b
where a.lockwait = b.kaddr; prompt "被等待的用戶"
select a.sid, a.serial#,
a. machine, a.last_call_et,a.username,
b. b.type,a.status,b.id1
from my_session a, my_lock b
where b.id1 in
(select distinct e.id1
from my_session d, my_lock e
where d.lockwait = e.kaddr)
and a.sid = b.sid
and b.request=0; prompt "查出其 sql "
select a.username, a.sid, a.serial#,
b.id1, b.type, c.sql_text
from my_session a, my_lock b, my_sqltext c
where b.id1 in
(select distinct e.id1
from my_session d, my_lock e
where d.lockwait = e.kaddr)
and a.sid = b.sid
and b.request=0
and c.hash_value =a.sql_hash_value; ---- 以上思路也可用于其它大型數據庫系統如 Informix, Sybase,DB2中。通過使用該腳本,可以極大地提高獲取系統中當前鎖等待的情況,從而及時解決數據庫應用系統中的鎖等待問題。而且,由于實際上已取出其 program 名及相應的 sql 語句,故可以在事后將其記錄下來,交給其開發人員進行分析并從根本上得到解決。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
怡红院精品视频| 国产免费观看久久黄| 欧美专区在线观看| 日韩成人在线播放| 国产成人久久精品| 久久在线精品视频| 久久久精品电影| 欧美亚洲第一区| 亚洲黄色www| 欧美另类极品videosbest最新版本| 久久久久久久国产精品视频| 成人黄色网免费| 日韩专区中文字幕| 久久久精品网站| 亚洲97在线观看| 日韩欧美成人精品| 高跟丝袜欧美一区| 日韩视频免费看| 亚洲最新av网址| 欧美最近摘花xxxx摘花| 色婷婷亚洲mv天堂mv在影片| 亚洲精品乱码久久久久久按摩观| 亚洲va久久久噜噜噜| 亚洲精品国产精品国自产观看浪潮| 欧美激情女人20p| 欧美激情网友自拍| 亚洲aa在线观看| www国产精品com| 精品国产乱码久久久久久婷婷| 久久69精品久久久久久久电影好| 日韩视频精品在线| 成人中心免费视频| 亚洲欧美另类自拍| 欧美成人精品h版在线观看| 欧美电影电视剧在线观看| 欧美成人高清视频| 91久久久久久久久| 亚洲午夜激情免费视频| 久久精品99无色码中文字幕| 51ⅴ精品国产91久久久久久| 日韩精品视频观看| 亚洲一区二区久久久| 久久全球大尺度高清视频| 久久久久久久久国产| 日韩av影片在线观看| 久久香蕉国产线看观看av| 这里只有精品在线播放| 日韩av网站导航| 日韩视频免费看| 欧美性高跟鞋xxxxhd| 正在播放欧美一区| 国产精品久久久久久久久久99| 亚洲丁香久久久| 日韩大胆人体377p| 欧美久久精品午夜青青大伊人| 久久久电影免费观看完整版| 国产精品成人aaaaa网站| 欧美性猛交xxxx乱大交极品| 日韩精品极品在线观看播放免费视频| 欧美激情18p| 57pao精品| 欧美亚洲日本黄色| 欧美日韩精品在线播放| 黑人狂躁日本妞一区二区三区| 亚洲成av人影院在线观看| 国内精品400部情侣激情| 亚洲欧美日韩国产中文专区| 国产精品美女www爽爽爽视频| 国产精品久久久亚洲| 亚洲韩国欧洲国产日产av| 色狠狠久久aa北条麻妃| 亚洲第一av网| 国产精品久久久久久久久久久久久| 亚洲美女性生活视频| 久久久久久久久国产| 久久99热精品| 欧美日韩国产999| 日韩黄色在线免费观看| 国产美女久久精品香蕉69| 亚洲色图第一页| 国产精品一区二区三区在线播放| 国内精品久久久久久久久| 中文字幕日韩有码| 日韩精品视频免费专区在线播放| 欧美日产国产成人免费图片| 亚洲一区中文字幕| 久99九色视频在线观看| 日韩69视频在线观看| 国产999在线观看| 91成人在线观看国产| 免费成人高清视频| 欧美成人国产va精品日本一级| 亚洲成人网久久久| 精品亚洲一区二区三区在线观看| 91免费的视频在线播放| 日韩视频在线免费| 国产精品免费在线免费| 国产精品96久久久久久又黄又硬| 国产一区二区黑人欧美xxxx| 国产精品男女猛烈高潮激情| 国产成人激情小视频| 黄色成人在线免费| 亚洲免费一在线| 国产视频在线一区二区| 国产成人精品一区| 久久91精品国产91久久久| 国产成人高潮免费观看精品| 亚洲国产另类 国产精品国产免费| 国产91ⅴ在线精品免费观看| 国产精品入口夜色视频大尺度| 欧美理论电影网| 国产日韩精品在线| 亚洲另类图片色| 亚洲欧美国产日韩天堂区| 国产精品自拍视频| 欧美精品videossex88| 亚洲国产精品大全| 亚洲免费伊人电影在线观看av| 色综合天天狠天天透天天伊人| 亚洲专区中文字幕| 97在线免费观看| 国产日韩欧美日韩| 欧美激情一级二级| 亚洲a级在线观看| 久久精品国产一区| 精品国产一区二区三区久久久狼| 亚洲欧美成人一区二区在线电影| 波霸ol色综合久久| 免费91麻豆精品国产自产在线观看| 欧美色视频日本版| 欧美激情第1页| 国产91网红主播在线观看| 日韩av在线免费观看| 国产精品网红直播| 91精品国产自产在线老师啪| 国内精品久久久久伊人av| 日韩高清不卡av| 亚洲成人精品视频在线观看| 国产精品高潮呻吟久久av无限| 日本国产精品视频| 中文字幕亚洲欧美日韩高清| 亚洲最大av在线| 国产精品视频一| 亚洲午夜性刺激影院| 国产精品三级久久久久久电影| 一区二区三区四区视频| 欧美一区二区三区精品电影| 日本中文字幕成人| 77777少妇光屁股久久一区| 精品无人区太爽高潮在线播放| 黄色成人在线免费| 国产精品亚洲第一区| 欧美大片va欧美在线播放| 欧美裸体xxxx极品少妇| 久久人91精品久久久久久不卡| 亚洲aⅴ男人的天堂在线观看| 日韩在线视频网站| 性欧美亚洲xxxx乳在线观看| 精品国产乱码久久久久久婷婷| 欧美午夜丰满在线18影院| 久久激情视频久久| 国产精品一区二区三区久久久| 97视频在线观看免费高清完整版在线观看| 中文字幕亚洲二区|