加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 16:23:57 所属栏目:百科 来源:网络整理
导读:在与DML和DDL语句一起使用时,在PL / SQL中执行immediate是什么意义?执行立即隐式提交到DDL语句之类的数据库吗? 以下是我遇到的一个例子: SELECT 'TRUNCATE TABLE BD_BIDS_APPR_DET' INTO V_SQL1 FROM DUAL;EXECUTE IMMEDIATE V_SQL1;SELECT 'TRUNCATE TAB
在与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.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读