- 浏览: 557948 次
- 性别:
- 来自: 杭州
文章分类
- 全部博客 (340)
- Spring (4)
- Hibernate (2)
- Linux (34)
- Oracle (145)
- Eclipse (1)
- UML (1)
- HTML&&JAVASCRIPT (11)
- JAVA (33)
- 设计模式 (1)
- 版本控制 (1)
- wrap框架 (3)
- IBATIS (5)
- Ruby (1)
- DWR (1)
- MINA (11)
- JBPM (2)
- 缓存技术 (4)
- 网络 (3)
- 应用服务器 (1)
- GWT (5)
- 杂谈 (2)
- ICE (4)
- XML (2)
- ArcGis (2)
- Flex (8)
- junit单元测试 (1)
- SNMP (1)
- 存储 (1)
- office (1)
- MongoDB (0)
- Greenplum (3)
- 管理点滴 (1)
- C++ (6)
- 网络入门 (3)
- Tomcat (7)
- JMX (0)
- webservice (1)
- Oracle的10046事件 (1)
- Library cache内部机制详解 (1)
- expdp通过dblink来导入 (1)
最新评论
-
yuanliangding:
有没有关于mock的更多知识。
基于mock对象和JUnit框架简化Spring Web组件单元测试 -
saup007:
ssh端口不是22,怎么搞呢?
Greenplum 学习笔记 -
springmvc-freemarker:
java开源项目源码实例下载
Apache上全部JAVA开源项目简介 -
bobbell:
哇塞,你真厉害,整理的非常全面。我是一个java barcod ...
Greenplum 学习笔记 -
wsj55133245513324:
这不是bug,你将日志级别从debug提升到INFO 就好了 ...
Spring,smppapi,apache mina, ssl快速实现安全的smpp(5)
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比以前可能用到的更容易并且更高效.当意图执行动态语句时,适当地处理异常更加重要.应该关注于捕获所有可能的异常.
发表评论
-
expdp通过dblink来导入
2011-12-14 15:01 1789create.sql: spo create.log rem ... -
Library cache内部机制详解
2011-12-14 14:55 893Library cache内部机制详解 http://www ... -
Oracle的10046事件
2011-12-14 14:53 2098Oracle的10046事件,可以跟踪应用程序所执行的SQL语 ... -
REDO LOG MEMBER STATUS 和 REDO LOG GROUP STATUS
2011-12-14 14:51 928V$LOG 中列出的是REDO LOG GROUP STA ... -
oracle的exp/imp使用方法学习(转)
2011-08-30 08:54 964exp/imp两个命令可以说是oracle中最常用的命令了 ... -
oracle几个awr报告
2011-08-09 14:25 900工作中,碰到的数据库慢的几个awr报告 -
Oracle Profile 使用详解
2011-06-21 14:41 972一、目的: Oracle系统中的profile可以用来对 ... -
ORA-27013
2011-04-13 14:25 1516很新的一个bug,看下你的 memory_target是不是& ... -
ACLE表连接方式分析及常见用法
2011-03-23 09:14 1115摘要: 针对在数据仓库 ... -
ORACLE 外部表应用
2011-03-09 14:58 1068SQL> create or replace direc ... -
How to convert a 32-bit database to 64-bit database on Linux
2011-02-18 14:09 1216How to convert a 32-bit databas ... -
expdp impdp 数据库导入导出命令详解
2011-02-16 09:10 1957一、创建逻辑目录,该命令不会在操作系统创建真正的目录,最 ... -
Oracle手工解/锁表
2011-01-25 14:15 2507手工锁表:lock table tbl_t1 in row ... -
oracle动态性能视图
2011-01-22 10:47 862Oracle动态性能视图个人整理 -
RBO规则介绍
2011-01-17 16:45 1082•无条件使用索引•使用内置的优先级别决定访问路径•比较难以 ... -
关于排序、sort_area_size、临时表空间
2011-01-13 15:30 1120简单陈述一下:针对每 ... -
创建索引ORACLE 需要做的工作
2011-01-13 14:53 1324一. 先来看一下创建索引要做哪些操作:1. 把inde ... -
表之间的连接
2011-01-13 10:42 798Join是一种试图将两个表结合在一起的谓词,一次只能连接2 ... -
重建索引的条件
2011-01-12 16:43 955如果索引存在碎片,那每个索引数据块上的索引数据就更少,会导致我 ... -
TKPROF使用学习
2011-01-10 17:38 726Tkprof工具可用来格式化sql trace产生的文件, ...
相关推荐
8. **动态SQL**:通过EXECUTE IMMEDIATE语句,可以执行在运行时构建的SQL语句,增强了程序的动态性。 9. **数据库链接**:允许用户从一个数据库访问另一个数据库的数据,实现分布式数据库操作。 10. **性能优化**...
4. **动态SQL**:探讨如何在PL/SQL中执行SQL语句,包括EXECUTE IMMEDIATE和PREPARE-EXECUTE-CLOSE模式,以及绑定变量的应用。 5. **包(PACKAGE)**:详细解释包的概念,包括公共和私有部分,以及如何通过包来组织...
11. **数据库对象的动态SQL**:通过EXECUTE IMMEDIATE和DBMS_SQL包,可以执行动态SQL,允许在运行时构建和执行SQL语句,提高了灵活性。 12. **数据库链接**:了解如何使用数据库链接(Database Links)在不同数据库...
- **动态SQL**:通过`EXECUTE IMMEDIATE`执行动态构建的SQL语句。 - **BULK COLLECT**:用于批量收集查询结果。 - **DBMS_OUTPUT.PUT_LINE**:用于输出结果到控制台。 **2. 转换cc表数据格式** - **知识点解析:...
8. **动态SQL**:有时你需要在运行时构建SQL语句,这可以通过EXECUTE IMMEDIATE语句实现,它允许你动态执行字符串形式的SQL。 9. **包(Package)**:包是一种组织PL/SQL对象(如过程、函数、变量)的方式,可以...
7. **动态SQL**:通过EXECUTE IMMEDIATE语句,可以在运行时构建和执行SQL语句,增强了灵活性。 8. **数据库链接**:PL/SQL可以创建和使用数据库链接,允许跨数据库的交互操作。 9. **事务管理**:PL/SQL支持事务的...
EXECUTE IMMEDIATE sql_query USING 20; END; ``` 在这个实例精讲中,你将学习如何使用PL/SQL进行数据操作,创建存储过程和函数,以及如何有效地处理错误和事务。通过对"student"数据库模式的实践,你将掌握...
通过EXECUTE IMMEDIATE语句,PL/SQL能够执行在运行时构建的SQL语句,增加了灵活性。 八、PL/SQL与表操作 PL/SQL可以直接插入、更新、删除和查询数据库中的数据。INSERT、UPDATE、DELETE语句用于修改表,而SELECT...
7. **动态SQL**:通过EXECUTE IMMEDIATE和DBMS_SQL模块,你可以编写和执行运行时构建的SQL语句,这在处理灵活的数据操作需求时非常有用。 8. **索引和性能优化**:示例可能包括如何利用索引来加速查询,以及如何...
总之,动态SQL中的EXECUTE IMMEDIATE是Oracle数据库开发中的重要工具,它提供了在运行时构建和执行SQL语句的能力,极大地扩展了PL/SQL的灵活性。但在使用过程中,应谨慎对待SQL注入风险,并确保遵循最佳实践,以提高...
15. **动态SQL**:通过EXECUTE IMMEDIATE语句,可以在运行时构建和执行SQL,增强了程序的灵活性。 通过深入学习和实践这些知识点,开发者可以熟练地利用Oracle PL/SQL进行数据库应用的开发和维护,提升系统的稳定性...
根据给定的信息,本文将详细解释动态PL/SQL的相关知识点,包括动态SQL的基本概念、如何使用`EXECUTE IMMEDIATE`语句创建表、插入数据以及查询数据等。 ### 动态SQL简介 在PL/SQL中,动态SQL指的是运行时才能确定其...
你可能会找到使用EXECUTE IMMEDIATE和PREPARE语句的示例。 10. **数据库链接(DB Links)**:如果包含,这部分可能涉及到如何使用PL/SQL通过数据库链接在不同的Oracle实例间通信。 通过这些源代码,开发者可以加深...
- EXECUTE IMMEDIATE:使用此命令执行字符串形式的SQL语句。 - INTO子句:用于将动态查询的结果赋值给变量。 - 游标FOR LOOP:与动态SQL结合,可以方便地遍历和处理动态查询结果。 在实际开发中,掌握这些基本...
Oracle 动态 SQL 中的 EXECUTE IMMEDIATE 语句是数据库中执行动态 SQL 语句或非运行时创建的 PL/SQL 块的重要工具。与 DBMS_SQL package 相比,EXECUTE IMMEDIATE 使用较简单,能够满足较常用的需要。 EXECUTE ...
7. **动态SQL**:使用EXECUTE IMMEDIATE语句,可以在运行时构建和执行SQL语句,这在处理不确定的SQL命令时非常有用。 8. **包(PACKAGE)**:包是PL/SQL的高级特性,允许将相关的变量、常量、过程和函数组合在一起...
在PL/SQL中,`EXECUTE IMMEDIATE`语句配合`USING`子句可以动态插入值,而游标也可以使用绑定变量,如`OPEN c1 FOR 'SELECT * FROM emp WHERE empno=:empno' USING empno;` 值得注意的是,DDL(Data Definition ...
`EXECUTE IMMEDIATE`语句用于执行动态SQL。 ##### 四、使用OPEN-FOR、FETCH和CLOSE语句 这些语句用于处理动态SQL的结果集。 ##### 五、使用批量动态SQL 批量动态SQL可以提高执行效率。 ##### 六、动态SQL的技巧与...
execute immediate 用法研究 ...Execute Immediate 是一个功能强大且灵活的语句,可以满足各种动态 SQL 语句和 PL/SQL 块的需求。但是,也需要注意使用技巧和限制,以确保正确和高效地使用 Execute Immediate。
7. **动态SQL**:使用EXECUTE IMMEDIATE执行字符串形式的SQL,适应动态构建SQL语句的需求。 8. **并发控制**:理解锁定和事务管理,确保数据的一致性和完整性。 9. **性能优化**:学习如何通过索引、物化视图、绑定...