回答

收藏

Oracle:DBMS_UTILITY.EXEC_DDL_STATEMENT与立即执行

技术问答 技术问答 158 人阅读 | 0 人回复 | 2023-09-14

DBMS_UTILITY.EXEC_DDL_STATEMENT和之间有EXECUTE IMMEDIATE 有什么区别?7 {1 D( s: h7 R, k8 G7 z
                                                                & H7 L: C4 r1 }7 l5 E9 p4 w
    解决方案:                                                                4 x/ _( T- o! Q/ J7 k. q1 B/ H
                                                                从根本上说,它们执行相同的操作,这是提供一种PL / SQL中执行DDL这台机器不支持语句的机制。如果内存对我有用,那就是Oracle9 A5 V0 V# I9 a
7版本的DBMS_UTILITY可用于软件包EXEC_DDL_STATEMENT,8中只引入本机动态SQL(EXECUTE IMMEDIATE)。' o( M' f. e1 J) g# _
有些区别。EXECUTEIMMEDIATE主要是关于执行动态SQL(如其NDS别名显示)。我们可以用它。DDL的事实是逐步的。而EXEC_DDL_STATEMENT()-就像建议一样-只能执行DDL。
2 w% L) n- n7 {  N; p" X' z" V但不仅仅是保留DBMS_UTILITY版本是向后兼容的。它还有一个整洁的技能,我们不能使用它EXECUTE IMMEDIATE来完成-# z5 W" J  `( ?- X& J/ _$ P
分布式运行DDL。我们可以从数据库上创建一个表,我们可以从本地数据库中运行此语句(假设我们的用户在那里有必要的特权):
6 U7 i/ U1 _7 c6 s; \' fSQL>  exec DBMS_UTILITY.EXEC_DDL_STATEMENT@remote_db('create table t1 (id number)');我不建议这样做,只是说可以。
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则