存储过程中慎用 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/
本文讨论了在Oracle存储过程中使用execute immediate执行DDL语句的风险。特别指出,在同一事务中DDL语句之前的数据操作会自动提交,这可能导致数据一致性问题。文章还提供了一个具体的例子来说明这一问题。
3863

被折叠的 条评论
为什么被折叠?



