分析依賴物件對當前失敗會話的影響

hooca發表於2015-04-08
一些會話語句失敗,可能與其所依賴的物件有關。比如對一個正在執行truncate的表,庫快取中會鎖住該表,同時再執行涉及這個表的儲存過程的編譯compile,必定無法成功。

檢查依賴物件涉及的會話:


點選(此處)摺疊或開啟

  1. SQL> SELECT * FROM V$ACCESS
  2.   WHERE (OWNER, OBJECT) IN
  3.   (SELECT REFERENCED_OWNER, REFERENCED_NAME FROM DBA_DEPENDENCIES
  4.   WHERE OWNER = 'FUJIANREP' AND NAME = 'P_GENERATE_REPDATA');
         SID  OWNER                            OBJECT                           TYPE 
---------- ------------------------------ ------------------------------ ------------ 
          54 FUJIANREP                        CAT_BUYER                        SYNONYM 
          54 FUJIANREP                        CAT_CATEGORY                     SYNONYM 
          54 FUJIANREP                        CAT_DOSEAGE_FORM                SYNONYM 
          54   FUJIANREP                        CAT_DRUG                         SYNONYM 
          54   FUJIANREP                        CAT_ENTERPRISE                   SYNONYM 
          54   FUJIANREP                        CAT_METRIC                       SYNONYM 

根據找出的SID,找出對應的會話

點選(此處)摺疊或開啟

  1. SQL> SELECT SID, SERIAL#, USERNAME, PROGRAM, TERMINAL 
  2.     FROM V$SESSION WHERE SID = 54;

  SID      SERIAL#   USERNAME                         PROGRAM       TERMINAL 
---------- ---------- ------------------------------ ------------ ---------- 
  54       26216   FUJIANREP                        PlSqlDev.exe   LIBY 

找出SQL語句

點選(此處)摺疊或開啟

  1. SQL> SELECT SQL_TEXT FROM V$SQL
  2.   WHERE ADDRESS IN (SELECT SQL_ADDRESS FROM V$SESSION WHERE SID = 54);

根據得出的資訊,分析原因。





來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22621861/viewspace-1544633/,如需轉載,請註明出處,否則將追究法律責任。

相關文章