存储过程中慎用 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/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/350519/viewspace-1033930/