`
Virgo_S
  • 浏览: 1150935 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

动态SQL和PL/SQL的EXECUTE选项分析

阅读更多
http://bbs.zdnet.com.cn/archiver/tid-133874.html
EXECUTE IMMEDIATE代替了以前Oracle8i中DBMS_SQL package包.它解析并马上执行动态的SQL语句或非运行时创建的PL/SQL块.动态创建和执行SQL语句性能超前,EXECUTE IMMEDIATE的目标在于减小企业费用并获得较高的性能,较之以前它相当容易编码.尽管DBMS_SQL仍然可用,但是推荐使用EXECUTE IMMEDIATE,因为它获的收益在包之上。
使用技巧
  1. EXECUTE IMMEDIATE将不会提交一个DML事务执行,应该显式提交。
  2. 如果通过EXECUTE IMMEDIATE处理DML命令,那么在完成以前需要显式提交或者作为EXECUTE IMMEDIATE自己的一部分. 如果通过EXECUTE IMMEDIATE处理DDL命令,它提交所有以前改变的数据。
  3. 不支持返回多行的查询,这种交互将用临时表来存储记录(参照例子如下)或者用REF cursors.
  4. 当执行SQL语句时,不要用分号,当执行PL/SQL块时,在其尾部用分号。
  5. 在Oracle手册中,未详细覆盖这些功能。下面的例子展示了所有用到Execute immediate的可能方面.希望能给你带来方便。
  6. 对于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比以前可能用到的更容易并且更高效.当意图执行动态语句时,适当地处理异常更加重要.应该关注于捕获所有可能的异常。
补充:
like 's%' 的动态sql语句该如何写?
SQL> create table t(id int , name varchar2(10));
表已创建。
SQL> insert into t values(1 , 'test');
已创建 1 行。
SQL> insert into t values(2 , 'abced');
已创建 1 行。
SQL> commit;
提交完成。
SQL> select * from t where name like 't%';
        ID NAME
---------- ----------
         1 test
SQL> declare
  2  v_string varchar2(100);
  3  v_t t%rowtype ;
  4  begin
  5  v_string:='select * from t where name like ''t%''';
  6  execute immediate v_string into v_t;
  7  dbms_output.put_line(v_t.id||' '||v_t.name) ;
  8  end;
  9  /
1 test
PL/SQL 过程已成功完成。
SQL>


分享到:
评论

相关推荐

    一个对数据库的操作工具PL/SQLpl/sqL工具

    8. **动态SQL**:通过EXECUTE IMMEDIATE语句,可以执行在运行时构建的SQL语句,增强了程序的动态性。 9. **数据库链接**:允许用户从一个数据库访问另一个数据库的数据,实现分布式数据库操作。 10. **性能优化**...

    Oracle PL/SQL专家指南-高级PL/SQL解决方案的设计与开发

    4. **动态SQL**:探讨如何在PL/SQL中执行SQL语句,包括EXECUTE IMMEDIATE和PREPARE-EXECUTE-CLOSE模式,以及绑定变量的应用。 5. **包(PACKAGE)**:详细解释包的概念,包括公共和私有部分,以及如何通过包来组织...

    oracle PL/SQL测试题目和详细答案

    - **动态SQL**:通过`EXECUTE IMMEDIATE`执行动态构建的SQL语句。 - **BULK COLLECT**:用于批量收集查询结果。 - **DBMS_OUTPUT.PUT_LINE**:用于输出结果到控制台。 **2. 转换cc表数据格式** - **知识点解析:...

    Oracle PL/SQL学习官方教材

    11. **数据库对象的动态SQL**:通过EXECUTE IMMEDIATE和DBMS_SQL包,可以执行动态SQL,允许在运行时构建和执行SQL语句,提高了灵活性。 12. **数据库链接**:了解如何使用数据库链接(Database Links)在不同数据库...

    PL/SQL入门到精通书的源代码

    8. **动态SQL**:有时你需要在运行时构建SQL语句,这可以通过EXECUTE IMMEDIATE语句实现,它允许你动态执行字符串形式的SQL。 9. **包(Package)**:包是一种组织PL/SQL对象(如过程、函数、变量)的方式,可以...

    PL/SQL development9.0.3

    7. **动态SQL**:通过EXECUTE IMMEDIATE语句,可以在运行时构建和执行SQL语句,增强了灵活性。 8. **数据库链接**:PL/SQL可以创建和使用数据库链接,允许跨数据库的交互操作。 9. **事务管理**:PL/SQL支持事务的...

    oracle pl/sql实例精讲student数据库模式数据和表脚本

    Oracle PL/SQL是一种强大的编程语言,它结合了SQL的数据库操作能力和Procedural Language的编程结构,用于在Oracle数据库环境中创建复杂的应用程序。在"Oracle PL/SQL实例精讲student数据库模式"中,我们将深入探讨...

    精通Oracle_PL/SQL

    精通Oracle PL/SQL》旨在教授读者写出健壮、高效且易于维护的 PL/SQL代码。全书涵盖了 PL/SQL提供的大量功能,包括高效数据处理、...《精通Oracle PL/SQL》结构清晰,示例丰富,实践性强,适用于 DBA和数据库开发人员。

    《精通Oracle PL/SQL》源码

    7. **动态SQL**:通过EXECUTE IMMEDIATE和DBMS_SQL模块,你可以编写和执行运行时构建的SQL语句,这在处理灵活的数据操作需求时非常有用。 8. **索引和性能优化**:示例可能包括如何利用索引来加速查询,以及如何...

    pl/sql语法详解

    通过EXECUTE IMMEDIATE语句,PL/SQL能够执行在运行时构建的SQL语句,增加了灵活性。 八、PL/SQL与表操作 PL/SQL可以直接插入、更新、删除和查询数据库中的数据。INSERT、UPDATE、DELETE语句用于修改表,而SELECT...

    Oracle PL/SQL Programming

    15. **动态SQL**:通过EXECUTE IMMEDIATE语句,可以在运行时构建和执行SQL,增强了程序的灵活性。 通过深入学习和实践这些知识点,开发者可以熟练地利用Oracle PL/SQL进行数据库应用的开发和维护,提升系统的稳定性...

    Oracle PL/SQL程序设计(第5版)源代码

    Oracle PL/SQL程序设计是数据库开发领域中一本权威的指南,尤其对于使用Oracle数据库进行存储过程、函数和其他数据库编程的开发者来说,具有极高的参考价值。第5版的书籍不仅涵盖了PL/SQL的基础知识,还深入探讨了...

    整理:oracle pl/sql 入门+ 数组使用+游标+动态SQL

    Oracle PL/SQL是Oracle数据库系统中的过程式编程语言,它扩展了SQL...通过阅读这个文档,你将获得关于Oracle PL/SQL的全面理解,包括如何在程序中有效地使用数组、游标和动态SQL,从而更好地管理和操作数据库中的数据。

    sql,PL/SQl学习笔记

    在PL/SQL中,`EXECUTE IMMEDIATE`语句配合`USING`子句可以动态插入值,而游标也可以使用绑定变量,如`OPEN c1 FOR 'SELECT * FROM emp WHERE empno=:empno' USING empno;` 值得注意的是,DDL(Data Definition ...

    动态PL/SQL用法例子

    根据给定的信息,本文将详细解释动态PL/SQL的相关知识点,包括动态SQL的基本概念、如何使用`EXECUTE IMMEDIATE`语句创建表、插入数据以及查询数据等。 ### 动态SQL简介 在PL/SQL中,动态SQL指的是运行时才能确定其...

    pl/sql工具

    7. **动态SQL**:使用EXECUTE IMMEDIATE语句,可以在运行时构建和执行SQL语句,这在处理不确定的SQL命令时非常有用。 8. **包(PACKAGE)**:包是PL/SQL的高级特性,允许将相关的变量、常量、过程和函数组合在一起...

    Oracle PL/SQL 帮助文档

    11. **动态SQL**:使用EXECUTE IMMEDIATE和OPEN FOR语句执行动态SQL。 12. **PL/SQL与SQL的交互**:讨论如何在PL/SQL中执行SQL语句,如DML(INSERT, UPDATE, DELETE)和DDL(CREATE, ALTER, DROP)。 13. **PL/SQL...

    Oracle PL SQL专家指南_高级PLSQL解决方案的设计与开发

    - 动态SQL:EXECUTE IMMEDIATE和DBMS_SQL包 - 游标表达式和游标变量的高级应用 - PL/SQL包和类型:创建和使用 - PL/SQL中的对象关系编程 10. **AppendixA - 实战案例与解决方案** - 解决实际问题的PL/SQL代码...

    oracle第三方工具 pl/sql8

    7. **动态SQL**:使用EXECUTE IMMEDIATE执行字符串形式的SQL,适应动态构建SQL语句的需求。 8. **并发控制**:理解锁定和事务管理,确保数据的一致性和完整性。 9. **性能优化**:学习如何通过索引、物化视图、绑定...

    Oracle PL/SQL常用47个工具包

    6. **动态SQL**:通过EXECUTE IMMEDIATE语句,PL/SQL可以执行在运行时构建的SQL语句,增强了灵活性,适用于处理不确定的或用户定义的SQL。 7. **嵌套表和集合类型**:这些数据类型允许在PL/SQL中存储一组值,类似于...

Global site tag (gtag.js) - Google Analytics