当在开发的应用场景中 数据库处理复杂业务逻辑里用到 SQL 语句拼接    可以用  execute immediate   来执行语 举个例子 insert into tb_temp_public(v1, v2, V3, V4, V5,V6,V7,V8,v9)  select '','','','','','','','','' from dual : tb_temp_public  里面的字段是动态生成的  后面对应的值也是动态生成的时候  这个时候执行语句  可以用: vsql   var…
  一.为什么要使用动态执行语句? 由于在PL/SQL 块或者存储过程中只支持DML语句及控制流语句,并不支持DDL语句,所以Oracle动态执行语句便应允而生了.关于DDL与DML的区别,请参见:DDL语句与DML语句及DCL和TCL. 二.动态执行语句怎么用? 动态执行语句代替了Oracle 8i中的DBMS_SQL Package包. 1)在PL/SQL中运行SQL语句,例如: 示例一: BEGIN               EXECUTE IMMEDIATE 'select count…
一.为什么要使用动态执行语句? 由于在PL/SQL 块或者存储过程中只支持DML语句及控制流语句,并不支持DDL语句,所以Oracle动态执行语句便应允而生了.关于DDL与DML的区别,请参见:DDL语句与DML语句及DCL和TCL. 二.动态执行语句怎么用? 动态执行语句代替了Oracle 8i中的DBMS_SQL Package包. 1)在PL/SQL中运行SQL语句,例如: 示例一: BEGIN               EXECUTE IMMEDIATE 'select count(u…
oracle 多条执行语句同时执行:begin 语名一;语句二; end; 注意 如果写在C#里千万不要用@的方法然后语句里有回车 例: string strSql = "begin update tablea set aa='1' where bb='"+'ddd'+"'; "+ " update tablea set aa='1' ; end;";…
一.在oracle项目开发中越到问题: 在利用ODP向oracle中插入数据时,如果这样写:   insert into clobTable (id, story) values(1,'....'); 其中story为clob类型   如果story的长度大于2000字节,直接插入将出现 ORA-01704:文字字符串过长 的错误. 解决方案:       方案一.利用参数   insert into clobTable (id, story) values(1,:story);   Oracl…
create or replace function fn_test2(tablename in varchar2) return number is rtn number; begin --通用的获取表的数据长度的函数 --执行的语句不是固定的,通过参数组合成的 --解决如何执行动态语句 execute immediate ' select count(1) from ' ||tablename into rtn; ---拼接语句时 from后面要记得加空格 return(rtn); --捕获…
一.静态SQL和动态SQL的概念. 1.静态SQL 静态SQL是我们常用的使用SQL语句的方式,就是编写PL/SQL时,SQL语句已经编写好了.因为静态SQL是在编写程序时就确定了,我们只能使用SQL中的DML和事务控制语句,但是DDL语句,以及会话控制语句却不能再PL/SQL中直接使用,如动态创建表或者某个不确定的操作时,这就需要动态SQL来实现. 2.动态SQL 动态SQL是指在PL/SQL编译时SQL语句是不确定的,如根据用户输入的参数的不同来执行不同的操作.编译程序对动态语句部分不进行处…
函数: 1 create or replace function fn_test(tablename in varchar2) return number is sqls ); rtn ):; begin --获取学生表的记录条数 --select count(*) into rtn from student; sqls:='select count(*) from ' || tablename; execute immediate sqls into rtn; dbms_output.put_…
--loop循环用法 (输出1到10) declare v_num number(2) := 0; begin loop v_num := v_num + 1; exit when v_num > 10; --上面退出循环也可以用下面3行 /* if(v_num > 9) then exit; end if;*/ dbms_output.put_line(v_num); end loop; end; --while loop循环用法 (输出1到10) declare v_num number(…
--loop循环用法 (输出1到10) declare v_num number(2) := 0; begin loop v_num := v_num + 1; exit when v_num > 10; --上面退出循环也可以用下面3行 /* if(v_num > 9) then exit; end if;*/ dbms_output.put_line(v_num); end loop; end; --while loop循环用法 (输出1到10) declare v_num number(…