儲存過程中慎用 execute immediate

itpremier發表於2010-05-26

儲存過程中慎用 execute immediate ,

execute immediate 執行DDL語句一定要小心,否則會造成資料一至性問題。

[@more@]

1,

create table t1( id1 number );

2,

begin
insert into t1 values (101) ;

execute immediate ' create table t2 (id1 number ) ';

end;
/

PL/SQL procedure successfully completed

資料已經被提交,無論你是否COMMIT。

如果一個過程中有多個DML語中,中間混雜了類似的DDL動態語句,就會造成DDL之前的語句提交,儘管DDL之後的語句失敗了,最終也無法將整個事物回滾到一致性狀態。

3,

begin
insert into t1 values (101) ;

execute immediate ' alter session enable parallel dml ' ;
end;
/

ORA-12841: Cannot alter the session parallel DML state within a transaction
ORA-06512: at line 8

但是"alter session" 這個DDL 語句不能在事物中執行。 必須首先提交或回滾事物。

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

相關文章