Oracle 11g DDL 的 wait選項(DDL_LOCK_TIMEOUT)

不一樣的天空w發表於2017-11-22

DDL命令需要排它鎖的內部結構。如果這些鎖不可用,將返回一個 ORA-00054: resource busy”,當試圖修改頻繁訪問的物件時,這可能特別讓人沮喪,為了解決這個問題Oracle 11g 包含了DDL_LOCK_TIMEOUT引數,可以在例項或者會話級別分別使用alter system alter session命令。

DDL_LOCK_TIMEOUT 表示一個DDL命令等待鎖可用的秒數在丟擲”resource busy”錯誤之前。預設值是0(表示NOWAIT)。

SQL> create  table  ddl_lock_test (

      id  number

     );

SQL> insert   into ddl_lock_test    values  ( 1 );

 

-----------建立一個測試表,並插入一條資料,但不commit;

-----------新開一個session,session 級別設定 DDL_LOCK_TIMEOUT 為一個非0值並試圖在表上加一列;

 

 

SQL> alter  session   set   ddl_lock_timeout = 20;

 

SQL>alter   table   ddl_lock_test   add  (

     name  varchar2(20)

      );

 

--------這個會話會等待20秒在失敗之前.

 alter  table  ddl_lock_test  add  (name  varchar2(20))

*

ERROR at line 1:

ORA-00054: resource busy and acquire with NOWAIT specified

 

----若我們重複alter  table 命令並在20秒內commit 第一個session insert , alter  table 將會返回執行成功訊息。

 

SQL>alter   table   ddl_lock_test   add  (

     name  varchar2(20)

      );

 Table  altered.

 

SQL>

 

 

詳細資訊請參考官方文件:

 

 

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

相關文章