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

主頁 > 知識庫 > 快速查出Oracle數據庫中鎖等待的方法

快速查出Oracle數據庫中鎖等待的方法

熱門標簽:電渠外呼系統 地圖標注怎么保存 外呼電話系統用卡嗎 廣東營銷智能外呼系統商家 高德地圖標注公司名字大全 車瑪仕極限運動場所地圖標注 七日殺a19.5全地圖標注 騰訊地圖標注要費用嗎 N個你智能電銷機器人

通常在大型數據庫系統中,為了保證數據的一致性,在對數據庫中的數據進行操作時,系統會進行對數據相應的鎖定。

這些鎖定中有"只讀鎖"、"排它鎖","共享排它鎖"等多種類型,而且每種類型又有"行級鎖"(一次鎖住一條記錄),"頁級鎖"(一次鎖住一頁,即數據庫中存儲記錄的最小可分配單元),"表級鎖"(鎖住整個表)。若為"行級排它鎖",則除被鎖住的該行外,該表中其它行均可被其它的用戶進行修改(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 語句,故可以在事后將其記錄下來,交給其開發人員進行分析并從根本上得到解決。

您可能感興趣的文章:
  • oracle11g用戶登錄時被鎖定問題的解決方法 (ora-28000 the account is locked)
  • oracle表被鎖定的完美解決方法
  • Oracle用戶被鎖的原因及解決辦法
  • Oracle數據表中的死鎖情況解決方法
  • ORACLE 查詢被鎖住的對象,并結束其會話的方法
  • Oracle刪除死鎖進程的方法
  • oracle查看被鎖的表和被鎖的進程以及殺掉這個進程
  • oracle修改scott密碼與解鎖的方法詳解
  • ORACLE 如何查詢被鎖定表及如何解鎖釋放session
  • oracle查詢鎖表與解鎖情況提供解決方案
  • Oracle 添加用戶并賦權,修改密碼,解鎖,刪除用戶的方法
  • Oracle鎖處理、解鎖方法

標簽:來賓 棗莊 大興安嶺 蘇州 贛州 玉樹 遼寧 長沙

巨人網絡通訊聲明:本文標題《快速查出Oracle數據庫中鎖等待的方法》,本文關鍵詞  快速,查出,Oracle,數據庫,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《快速查出Oracle數據庫中鎖等待的方法》相關的同類信息!
  • 本頁收集關于快速查出Oracle數據庫中鎖等待的方法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产一区啦啦啦在线观看| 欧美一区二区三区免费大片| 久久精品国产网站| 亚洲激情校园春色| 亚洲欧美一区二区三区久本道91 | 性感美女极品91精品| 国产永久精品大片wwwapp | 日精品一区二区| 国产精品人成在线观看免费| 欧美成人三级电影在线| 欧美区视频在线观看| 伊人一区二区三区| 欧美午夜精品久久久久久孕妇| 成人国产精品免费观看视频| 欧美不卡激情三级在线观看| 欧美性受极品xxxx喷水| 精品亚洲免费视频| 国产精品18久久久久久久久久久久 | 91精品免费观看| 欧美久久久久久久久久| 97久久人人超碰| 91久久精品国产91性色tv| 国产精品一区在线观看乱码| 欧美一级高清片| 国产综合成人久久大片91| 国产精品久久二区二区| 欧美精品自拍偷拍动漫精品| 偷窥国产亚洲免费视频| 另类小说图片综合网| 国产69精品一区二区亚洲孕妇| 色综合久久综合网欧美综合网| 2021久久国产精品不只是精品| 国内精品免费**视频| 日韩精品中文字幕在线一区| 欧美老人xxxx18| 国产精品久久久久久久久久久免费看 | 国产综合色视频| 亚洲国产精品一区二区www在线| 亚洲青青青在线视频| 欧美影视一区二区三区| 亚洲风情在线资源站| 亚洲成人动漫av| 成人深夜在线观看| 精品国产一区二区在线观看| 欧美日韩国产精品自在自线| 欧美一级在线免费| 亚洲午夜在线电影| 欧美专区在线观看一区| 久久久久一区二区三区四区| 一本大道av伊人久久综合| 欧美国产精品v| 99r国产精品| 国产欧美视频在线观看| 国产精品99久久久| 久久先锋影音av| 黄页视频在线91| 2020国产精品自拍| 国产乱码精品一品二品| 久久久久久日产精品| 欧美一区二区三区日韩视频| 欧美亚洲动漫精品| 91免费在线看| 一区二区三区在线观看欧美| 日韩精品午夜视频| 欧洲精品一区二区| 4438成人网| 综合久久久久久| 粗大黑人巨茎大战欧美成人| 久久精品在这里| 久久99热这里只有精品| 欧美日韩一区二区三区在线看| 亚洲天堂福利av| 日韩电影免费一区| 91精品国产综合久久久蜜臀粉嫩| 一区二区三区精品| 精品综合免费视频观看| 亚洲丝袜美腿综合| 国产精品成人网| 国产精品综合二区| 狠狠色丁香九九婷婷综合五月| 亚洲精品一区二区精华| 欧美日本在线看| 成人深夜福利app| 久久精品国产成人一区二区三区| 国产精品午夜免费| 久久久精品黄色| 欧美一区二区在线观看| 日本 国产 欧美色综合| 亚洲综合999| 亚洲综合色噜噜狠狠| 国产精品福利影院| 国产精品乱子久久久久| 久久综合九色综合久久久精品综合 | 丁香一区二区三区| 久久99日本精品| 久久你懂得1024| 欧美精品一区二区三区蜜臀| 美女视频黄 久久| 天堂在线亚洲视频| 日韩黄色一级片| 综合久久综合久久| 亚洲欧美怡红院| 午夜激情综合网| 国产精品亚洲视频| 日韩三级电影网址| 欧美一级片在线| 成年人午夜久久久| 欧洲国内综合视频| 欧美日韩国产欧美日美国产精品| 欧美网站一区二区| 一本一道波多野结衣一区二区| 欧美年轻男男videosbes| 欧美一卡二卡三卡| 国产精品久久精品日日| 国产精品国产三级国产aⅴ入口 | 亚洲精品大片www| 久久国产精品99精品国产| 久久一留热品黄| 国产精品狼人久久影院观看方式| 亚洲品质自拍视频网站| 1024精品合集| 亚洲综合激情网| 日韩成人一区二区三区在线观看| 热久久一区二区| 一区二区免费在线播放| 国产精品日韩成人| 亚洲伊人伊色伊影伊综合网| 精品国产99国产精品| 国产福利精品一区二区| 在线观看www91| 在线视频一区二区免费| 国产精品1区2区3区在线观看| 久久综合999| 激情六月婷婷久久| 久久久久久久综合色一本| 91色九色蝌蚪| 久久久久97国产精华液好用吗| 青娱乐精品视频在线| 91福利小视频| 免费成人小视频| 亚洲国产精品久久人人爱| 奇米一区二区三区| 国产精品一区专区| 欧美在线观看一二区| 天堂影院一区二区| 色综合天天综合狠狠| 国产精品亚洲一区二区三区在线 | 久久精品国产**网站演员| 欧美视频一区在线| 国产精品久久久久一区| 成人激情视频网站| 欧美一卡二卡在线观看| 中国色在线观看另类| 成人av在线资源网站| 久久影视一区二区| 成人国产电影网| 国产欧美久久久精品影院| 不卡电影一区二区三区| 精品国产乱码久久久久久免费 | 亚洲免费毛片网站| yourporn久久国产精品| 精品国产免费一区二区三区四区| 久久99精品久久只有精品| 欧美另类久久久品| 国产精品国产自产拍在线| 色婷婷综合久久| 亚洲美女免费在线| 成人一级片在线观看| 日韩免费观看高清完整版在线观看| 99精品视频中文字幕| 一区二区三区中文字幕精品精品| 国产精品一区二区三区四区| 中文一区二区在线观看| 成人免费视频国产在线观看| 久久精品理论片| 自拍偷拍亚洲欧美日韩| 91在线观看免费视频| 五月天激情小说综合| av激情综合网| 欧美aaaaaa午夜精品| 国产精品免费aⅴ片在线观看| 国产精品99久久久久久久vr| 亚洲最色的网站| 欧美电影精品一区二区| 一本一本久久a久久精品综合麻豆| 亚洲视频 欧洲视频| 精品国产第一区二区三区观看体验| 国产精品99久久久久久似苏梦涵| 日韩片之四级片| 欧美怡红院视频| 国内精品免费**视频| 欧美一级午夜免费电影| 国产一区二区三区国产| 日韩色在线观看| 在线视频国内一区二区| 美女高潮久久久| 亚洲va国产va欧美va观看| 欧美v亚洲v综合ⅴ国产v| 欧美军同video69gay| 成人视屏免费看|