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. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |