Oracle:“立即执行”是什么意思?

前端之家收集整理的这篇文章主要介绍了Oracle:“立即执行”是什么意思?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在与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.

原文链接:https://www.f2er.com/oracle/242102.html

猜你在找的Oracle相关文章