解決Oracle視圖被鎖住的問題

來源:互聯網
上載者:User

會產生這種視力被鎖定的現象是刪除某個對象的時候進程會死掉,建立的時候也是一樣。

我同事解釋的可能原因是:
在建立對象的時候沒有建立完就被關掉了,或者就是沒有執行完。然後造成線程鎖定。

解決的辦法:

1.找出等待事件的原因
select event,p1,p2,sid from v$session_wait where event not like 'SQL%' and event not like 'rdbms%';
2.找出鎖住的進程
select object_id,session_id,locked_mode from v$locked_object;
3.找出鎖住的進程的作業系統進程
select spid from v$process where addr=(select paddr from v$session where sid=19);(這個19表示被鎖定的SID)
4.在作業系統上刪除進程
orakill eoffice 2768(第一個參資料是資料庫的SID  第二個參數是進程ID,這個數字就是上面取到的進程ID,這個是在Dos命令視窗下操作)

下面是一個操作執行個體
首先先Drop 相關的鎖定的對象如Drop View vw_wf_CritCondition,然後結束PL/SQL Dev 再開一次才能執行下面的操作。

SQL> select event,p1,p2,sid from v$session_wait where event not like 'SQL%' and event not like 'rdbms%';

EVENT                                                                    P1         P2        SID
---------------------------------------------------------------- ---------- ---------- ----------
null event                                                       1413697536          1         18
null event                                                                1      95552         22
pmon timer                                                              300          0          1
smon timer                                                              300          0          5
library cache lock                                                763239564  792075180         23   (這裡表示有一個庫被鎖掉了。)
wakeup time manager                                                       0          0          8

6 rows selected

SQL> select object_id,session_id,locked_mode from v$locked_object;

 OBJECT_ID SESSION_ID LOCKED_MODE
---------- ---------- -----------
        77         22           3
        69         22           3
        70         22           3
       316         22           3
       314         22           3
       356         22           3
        68         22           3
        72         22           3
        73         22           3
        74         22           3
        75         22           3

11 rows selected

SQL> select spid from v$process where addr=(select paddr from v$session where sid=22);

SPID
------------
3348

在Dos操作,而且只能在安裝資料的本機操作
orakill eoffice 3348

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.