在与DML和DDL语句一起使用时,在PL / SQL中执行immediate是什么意义?执行立即隐式提交到DDL语句之类的数据库吗?
以下是我遇到的一个例子:
SELECT 'TRUNCATE TABLE BD_BIDS_APPR_DET' INTO V_SQL1 FROM DUAL; EXECUTE IMMEDIATE V_SQL1; SELECT 'TRUNCATE TABLE BD_BIDS_SYS_DET' INTO V_SQL1 FROM DUAL; EXECUTE IMMEDIATE V_SQL1; SELECT 'TRUNCATE TABLE BD_BIDS_EXT_DET' INTO V_SQL1 FROM DUAL; EXECUTE IMMEDIATE V_SQL1;
它用于运行本机
dynamic SQL.
对于DML,您在运行编译时没有的语句时会使用它,例如:如果列列表基于用户的选择.
在您的情况下,它被使用,因为DDL不能从PL / SQL中作为静态SQL运行.只有certain query,DML and TCL commands are valid.其他任何东西都必须被视为动态的.
我说很少需要使用PL / SQL块中的DDL. TRUNCATE可能是合理的;如果您发现任何动态创建或丢弃对象,那么这可能更令人担忧,因为它可能会建议一个次优的数据模型.
EXECUTE IMMEDIATE本身不会自动提交;但是如果你执行DDL那么它的行为就像你在PL / SQL之外运行一样,所以它会在你的情况下提交,是的.
顺便说一下,我不确定为什么你的代码使用中间变量来保存语句;如果您想要显示它将要运行的内容,这很有用,但您似乎并没有这样做.你有什么可以做到:
EXECUTE IMMEDIATE 'TRUNCATE TABLE BD_BIDS_EXT_DET';
即根本不使用V_SQL_1.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。