`

EXECUTE IMMEDIATE及Using的使用方法...

阅读更多

这段代码同样是执行了1000条insert语句,但是每一条语句都是不同的,因此ORACLE会把每条语句硬解析一次,其效率就比前面那段就低得多了。如果要提高效率,不妨使用绑定变量将循环中的语句改为

      sqlstr:='insert into 测试表 (:i,:i+1,:i*1,:i*2,:i-1) ';

      execute immediate sqlstr using i,i,i,i,i;

这样执行的效率就高得多了。

我曾试着使用绑定变量来代替表名、过程名、字段名等,结果是语句错误,结论就是绑定变量不能当作嵌入的字符串来使用,只能当作语句中的变量来用。

从效率来看,由于oracle10G放弃了RBO,全面引入CBO,因此,在10G中使用绑定变量效率的提升比9i中更为明显。

最后,前面说到绑定变量是在通常情况下能提升效率,那哪些是不通常的情况呢?

答案是:在字段(包括字段集)建有索引,且字段(集)的集的势非常大(也就是有个值在字段中出现的比例特别的大)的情况下,使用绑定变量可能会导致查询计划错误,因而会使查询效率非常低。这种情况最好不要使用绑定变量。

 

 

 

 

 

 

 

EXECUTE IMMEDIATE代替了以前Oracle8i中DBMS_SQL package包.它解析并马上执行动态的SQL语句或非运行时创建的PL/SQL块.动态创建和执行SQL语句性能超前,EXECUTE IMMEDIATE的目标在于减小企业费用并获得较高的性能,较之以前它相当容易编码.尽管DBMS_SQL仍然可用,但是推荐使用EXECUTE IMMEDIATE,因为它获的收益在包之上。

使用技巧

 

1. EXECUTE IMMEDIATE将不会提交一个DML事务执行,应该显式提交
如果通过EXECUTE IMMEDIATE处理DML命令,那么在完成以前需要显式提交或者作为EXECUTE IMMEDIATE自己的一部分. 如果通过EXECUTE IMMEDIATE处理DDL命令,它提交所有以前改变的数据

 

2. 不支持返回多行的查询,这种交互将用临时表来存储记录(参照例子如下)或者用REF cursors.

 

3. 当执行SQL语句时,不要用分号,当执行PL/SQL块时,在其尾部用分号.

 

4. 在Oracle手册中,未详细覆盖这些功能。下面的例子展示了所有用到Execute immediate的可能方面.希望能给你带来方便.

 

5. 对于Forms开发者,当在PL/SQL 8.0.6.3.版本中,Forms 6i不能使用此功能.

 

EXECUTE IMMEDIATE用法例子

 

1. 在PL/SQL运行DDL语句


begin
execute immediate 'set role all';
end;

 

2. 给动态语句传值(USING 子句)


declare
l_depnam varchar2(20) := 'testing';
l_loc    varchar2(10) := 'Dubai';
begin
execute immediate 'insert into dept values (:1, :2, :3)'
    using 50, l_depnam, l_loc;
commit;
end;

 

3. 从动态语句检索值(INTO子句)


declare
l_cnt    varchar2(20);
begin
execute immediate 'select count(1) from emp'
    into l_cnt;
dbms_output.put_line(l_cnt);
end;

 

4. 动态调用例程.例程中用到的绑定变量参数必须指定参数类型.黓认为IN类型,其它类型必须显式指定

 

declare
l_routin   varchar2(100) := 'gen2161.get_rowcnt';
l_tblnam   varchar2(20) := 'emp';
l_cnt      number;
l_status   varchar2(200);
begin
execute immediate 'begin ' || l_routin || '(:2, :3, :4); end;'
    using in l_tblnam, out l_cnt, in out l_status;

if l_status != 'OK' then
     dbms_output.put_line('error');
end if;
end;

 

5. 将返回值传递到PL/SQL记录类型;同样也可用%rowtype变量


declare
type empdtlrec is record (empno number(4),
                           ename varchar2(20),
                           deptno number(2));
empdtl empdtlrec;
begin
execute immediate 'select empno, ename, deptno ' ||
                   'from emp where empno = 7934'
    into empdtl;
end;

 

6. 传递并检索值.INTO子句用在USING子句前

 

declare
l_dept    pls_integer := 20;
l_nam     varchar2(20);
l_loc     varchar2(20);
begin
execute immediate 'select dname, loc from dept where deptno = :1'
    into l_nam, l_loc
    using l_dept ;
end;

 

7. 多行查询选项.对此选项用insert语句填充临时表,用临时表进行进一步的处理,也可以用REF cursors纠正此缺憾.

declare
l_sal   pls_integer := 2000;
begin
execute immediate 'insert into temp(empno, ename) ' ||
                   '          select empno, ename from emp ' ||
                   '          where sal > :1'
    using l_sal;
commit;
end;

 

       对于处理动态语句,EXECUTE IMMEDIATE比以前可能用到的更容易并且更高效.当意图执行动态语句时,适当地处理异常更加重要.应该关注于捕获所有可能的异常.

分享到:
评论

相关推荐

    Oracle中EXECUTE IMMEDIATE用法

    随着版本的演进,如在Oracle Forms 6i及以后的版本中,对`EXECUTE IMMEDIATE`的支持变得更加成熟和稳定。 ### 实际应用示例 1. **设置角色**: ```sql BEGIN EXECUTE IMMEDIATE 'SET ROLE ALL'; END; ``` 这...

    execute immediate 用法研究

    execute immediate 用法研究 Execute Immediate 是 Oracle 中的一个功能强大且灵活的语句,它可以解析并马上执行动态的 SQL 语句或非...但是,也需要注意使用技巧和限制,以确保正确和高效地使用 Execute Immediate。

    oracle动态sql之EXECUTE IMMEDIATE.docx

    Oracle 动态 SQL 之 EXECUTE IMMEDIATE Oracle 动态 SQL 中的 EXECUTE IMMEDIATE 语句是数据库中执行...这些示例展示了 EXECUTE IMMEDIATE 语句的使用方法和灵活性,使得开发者可以根据需要灵活地构建动态 SQL 语句。

    动态SQL之EXECUTE IMMEDIATE

    EXECUTE IMMEDIATE dynamic_sql_string [USING bind_variable_list]; ``` - `dynamic_sql_string`:这是个字符串,包含了待执行的SQL语句。 - `bind_variable_list`(可选):一个或多个变量,它们将在执行SQL时被...

    ORACLE数据库使用动态SQL的方法.pdf

    2. 使用`EXECUTE IMMEDIATE`配合`INTO`和`USING`子句,可以动态执行查询并获取结果,例如: ``` DECLARE var1 NUMBER; BEGIN EXECUTE IMMEDIATE 'SELECT column FROM table WHERE condition = :1' INTO var1 ...

    EXECUTE IMMEDIATE用法小结

    - **传值给动态SQL**:通过`USING`子句,如`BEGIN EXECUTE IMMEDIATE 'insert into dept values (:1, :2, :3)' USING 50, 'testing', 'Dubai'; COMMIT; END;` - **从动态SQL检索值**:使用`INTO`子句,如`DECLARE ...

    Oracle中Using用法

    动态 SQL 的开发思想是根据用户输入或其他条件来生成 SQL 语句,然后使用 EXECUTE IMMEDIATE 语句执行该语句。动态 SQL 的优点是可以实现灵活的查询和操作,但也存在一些性能损失。 三、Using 语句的使用 Using ...

    存储过程简单案例以及使用方法参考.pdf

    EXECUTE IMMEDIATE 'CALL PROC_NAME(:param1)' USING val1; ``` 对于有确定数目输入输出参数的情况,可以是: ``` EXECUTE IMMEDIATE 'CALL PROC_NAME(:in1, :out1)' USING in_val, out_var; ``` 最后,如果输出结果...

    oracle动态函数执行[文].pdf

    此外,`EXECUTE IMMEDIATE`还可以结合`INTO`关键字将查询结果直接赋值给变量,或者使用`USING`子句来传递参数。例如: ```sql DECLARE v_sql VARCHAR2(100); v_result VARCHAR2(50); BEGIN v_sql := 'SELECT loc...

    达梦数据库用户手册基础学习版.rar

    8.6.1 EXECUTE IMMEDIATE 立即执行语句...................... 278 8.6.2 PREPARE 准备语句 ................................... 278 8.6.3 EXCUTE 执行语句 .................................... 279...

    PowerBuilder下动态SQL语句的使用.pdf

    语法:EXECUTE IMMEDIATE SQLStatement [USING TransactionObject] ; 例如: EXECUTE IMMEDIATE 'CREATE TABLE school (code char(6), name char(30))' USING SQLCA ; 2. 第二种动态SQL语句 该格式可以用来执行...

    Oracle动态SQL之本地动态SQL的使用.pdf

    在处理动态SQL时,如果有需要绑定参数,则可以在EXECUTE IMMEDIATE命令中使用USING子句,将SQL语句中的占位符替换为具体的参数值。如果是执行包含RETURNING子句的非查询DML语句,则可以使用RETURNING INTO子句来获取...

    学习oracle动态函数执行.pdf

    3. 使用绑定变量执行SQL:`EXECUTE IMMEDIATE 'sql' USING [IN|OUT|IN OUT] bind_var_1, [IN|OUT|IN OUT] bind_var_2;` 4. 使用`RETURNING INTO`子句:`EXECUTE IMMEDIATE 'sql' RETURNING INTO var_1;` 5. 批量收集...

    Oracle过程中创建视图实例

    本文将深入探讨如何在Oracle过程中使用`EXECUTE IMMEDIATE`来创建视图实例,并介绍其使用场景、语法结构以及注意事项。 #### 一、`EXECUTE IMMEDIATE`概述 `EXECUTE IMMEDIATE`是Oracle PL/SQL中用于执行动态SQL...

    动态PL/SQL用法例子

    接下来的例子展示了如何使用`EXECUTE IMMEDIATE`结合`USING`子句来插入数据: ```plsql DECLARE id NUMBER := 1; BEGIN EXECUTE IMMEDIATE 'INSERT INTO test_qiu VALUES (:1)' USING id; COMMIT; END; ``` ...

    oracle动态函数执行.pdf

    在动态SQL中,`EXECUTE IMMEDIATE`的使用方式主要有以下几种: 1. **无变量绑定**: ```sql execute immediate 'sql_statement'; ``` 这种情况下,`sql_statement`是完整的SQL语句,不涉及任何输入或输出变量。...

    浅析PowerBuilder下动态SQL语句.pdf

    语法简洁,使用EXECUTE IMMEDIATE SQLStatement;语句,其中SQLStatement可以是直接用引号引起来的SQL语句,也可以是字符串变量形式的SQL语句。事务对象TransactionObject默认值为SQLCA。 应用实例: - 创建数据库...

    oracle-dynamic-SQL.rar_oracle_sql中dynamic用法

    动态SQL的实现主要通过两种方法:直接执行(EXECUTE IMMEDIATE)和PREPARE/EXECUTE组合。下面将详细讲解这两种方法及其应用。 1. 直接执行(EXECUTE IMMEDIATE): 这种方式是直接将SQL语句作为字符串传递给数据库...

    PB动态SQL语句

    这种格式使用 EXECUTE IMMEDIATE 语句,可以执行没有输入参数并且没有返回结果集的 SQL 语句。例如,创建一张数据库表、插入一条记录等。 EXECUTE IMMEDIATE ‘CREATE TABLE base(code char(6),name char(30))’ ...

Global site tag (gtag.js) - Google Analytics