解析并马上执行动态语句 ,或非运行时创建的pl/sql块 1. 不提交dml事务,要显式提交; execute immediate处理ddl,会提交所以以前改变的数据; 2.不支持多行查询,可以临时表 或者ref cursors 3.执行sql不需语句,执行pl/sql 要加分号; --0.传入 declare i_aac001 number(6):=111; begin execute immediate 'insert into a2(aac001) values(:1)' using i_aac001; end; insert into a2(aac001) values(1); insert into a2(aac001) values(2); --1.传入/传出 declare cnt number(6); begin execute immediate 'select 1 from dual where 1=:1' into cnt using cnt; dbms_output.put_line(cnt); end; --2.调用存储过程 declare s1 varchar2(10); s2 varchar2(10); begin execute immediate 'begin test1(:1,:2); end;' using s1,s2; end; --3.传值到记录 declare --类型 --声明 type type_a is record(str varchar2(10)); v_a type_a; v_b a2%rowtype; begin execute immediate 'select * from a2 where aac001=1742178' into v_b; end; --4.多行查询 用临时表 或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; http://baiyaoming.iteye.com/blog/1255016 for in 变量声明类型 ------------------------------- declare cursor cur is select * from a2; begin for c in (select * from a2) loop dbms_output.put_line(c.aac002); end loop; end; insert into a2(aac001) values(1); declare type t_a is table of a2%rowtype; type t_b is table of number(10) index by pls_integer; v_a t_a; v_b t_b; begin select aac001 bulk collect into v_b from a2; for i in v_b.first..v_b.last loop dbms_output.put_line(v_b(i)); end loop; end;
发表评论
-
adb命令
2012-08-09 14:28 1369ADB install app.apk ADB shell ... -
sqlite3
2012-08-09 13:02 956.mode column; .header on; al ... -
Oracle 10G:PL/SQL正规表达式(正则表达式)
2012-03-23 18:47 791Oracle 10G:PL/SQL正规表达式(正则表达式) ... -
生产区重新部署web
2012-03-09 22:38 702http://middleware123.com/weblog ... -
procedure 学习
2012-03-09 10:54 785http://hi.baidu.com/test2704/bl ... -
dblink
2012-03-09 10:05 4732三. 创建DBLINK的方法: 1. create p ... -
oracle 子分区
2012-01-30 10:43 3923--1.创建表空间 create tablespace ... -
厅表tp_ac01
2011-10-25 20:18 0create table tp_ac01 as select ... -
oracle 添加定时任务
2011-09-16 16:31 958--submit select * from repor ... -
decode和case的参数区别 timestamp date
2011-08-23 14:58 895SELECT DECODE('AA ', 'AA', '= ... -
oracle 用一个表更新另一个表
2011-07-11 10:19 30641.生成临时表 update (select a.aaa,b. ... -
semi join anti-join
2011-07-06 17:24 0使用in exists 用semi-join set aut ... -
终止oracle正在执行的存储过程
2011-06-14 14:13 4949--查看运行的procedure (表提供对象在libra ... -
oracle 并行
2011-05-13 14:52 0多的的地对地导弹的 -
oracle 级联查询 级联求和 汇总
2011-04-29 15:12 2662级联查询 select level||'层',lpad ... -
oracle中文日期 Oracle数据库中的''与NULL的
2011-04-13 10:48 1228转自:http://micki.blogbus.com/log ... -
[转]无法启动oracleDBConsole的解决方案之一
2011-02-21 22:24 962http://www.iteye.com/topic/6472 ... -
oracle触发器与存储过程(第10章)
2011-02-09 17:09 0--包调用方式 biology_degrees integer ... -
pk_imp_benefit(未完成)
2011-02-09 11:26 0n_sql := 'select ffqsny,yhzh00 ... -
sql迁移到oracle
2011-01-31 22:26 1024用oracle专用工具 jdk 1.6_1 ...
相关推荐
在Oracle数据库中,`EXECUTE IMMEDIATE`是一个非常强大的特性,允许在运行时动态执行SQL语句或PL/SQL块。这一功能自Oracle 8i版本的DBMS_SQL包引入以来,极大地增强了PL/SQL的灵活性和动态性。通过`EXECUTE ...
Execute Immediate 是 Oracle 中的一个功能强大且灵活的语句,它可以解析并马上执行动态的 SQL 语句或非运行时创建的 PL/SQL 块。 Execute Immediate 的目标是减小企业费用并获得较高的性能,较之以前它相当易于编码...
总之,动态SQL中的EXECUTE IMMEDIATE是Oracle数据库开发中的重要工具,它提供了在运行时构建和执行SQL语句的能力,极大地扩展了PL/SQL的灵活性。但在使用过程中,应谨慎对待SQL注入风险,并确保遵循最佳实践,以提高...
Oracle 动态 SQL 之 EXECUTE IMMEDIATE Oracle 动态 SQL 中的 EXECUTE IMMEDIATE 语句是数据库中执行动态 SQL 语句或非运行时创建的 PL/SQL 块的重要工具。与 DBMS_SQL package 相比,EXECUTE IMMEDIATE 使用较...
"execute immediate" 是Oracle数据库中的动态SQL执行语句,但在这里我们讨论的是SQL Server,它使用不同的命令来实现类似的功能。不过,我们可以理解这个描述是在尝试通过编程方式自动化SQL Server的备份恢复过程。...
"Oracle中执行动态SQL" Oracle中执行动态SQL是指在...Oracle中执行动态SQL可以使用动态游标或EXECUTE IMMEDIATE两种方法。动态游标可以实现灵活的SQL语句生成,而EXECUTE IMMEDIATE可以提供高性能的动态SQL执行。
`EXECUTE IMMEDIATE`是Oracle数据库中的一个关键特性,用于执行动态SQL语句或PL/SQL块。在Oracle 8i之前,`DBMS_SQL`包是处理动态SQL的主要工具,但`EXECUTE IMMEDIATE`的引入提供了一种更简单、更高效的替代方案。...
最后,执行任意SQL语句,例如更新表中的数据,可以使用`EXECUTE IMMEDIATE`命令: ```sql EXECUTE IMMEDIATE 'UPDATE 表名 SET 列 = 值 WHERE 条件'; ``` 批处理文件可以包含这些命令,并通过`exit`命令在完成所有...
3. **执行 SQL**:通过 `ocilib_statement_prepare` 准备 SQL 语句,然后用 `ocilib_statement_execute` 执行。 4. **绑定和获取结果**:使用 `ocilib_statement_bind_variable` 绑定输入/输出变量,`ocilib_...
总的来说,Oracle的动态函数执行通过`EXECUTE IMMEDIATE`提供了强大的灵活性,让我们能够构建和执行各种动态的SQL操作,但同时也需要谨慎处理以防止安全问题。在实际开发中,应根据具体需求合理运用这一特性,提高...
本文将深入探讨如何在Oracle过程中使用`EXECUTE IMMEDIATE`来创建视图实例,并介绍其使用场景、语法结构以及注意事项。 #### 一、`EXECUTE IMMEDIATE`概述 `EXECUTE IMMEDIATE`是Oracle PL/SQL中用于执行动态SQL...
在Oracle中,我们可以通过存储过程中的`EXECUTE IMMEDIATE`语句动态执行SQL语句,包括创建视图。例如: ```sql CREATE OR REPLACE PROCEDURE P_View1 AS BEGIN EXECUTE IMMEDIATE 'CREATE OR REPLACE VIEW V_View1...
插入字符串作为 Oracle EXECUTE IMMEDIATE 语句 用法:编辑 -> 转换为 PHP 字符串(ctrl + alt + shift + P) 安装: 下载ideaHelpfulPlugins.jar 在 phpStorm Settings -> Plugins -> Install plugin from disk...
在Oracle中,`EXECUTE IMMEDIATE`语句用于动态执行SQL或者PL/SQL代码,这对于处理不确定的数据操作或者根据用户输入构建查询非常有用。 首先,我们来看一个例子,这个例子展示了如何使用`EXECUTE IMMEDIATE`执行一...
动态 SQL 的开发思想是根据用户输入或其他条件来生成 SQL 语句,然后使用 EXECUTE IMMEDIATE 语句执行该语句。动态 SQL 的优点是可以实现灵活的查询和操作,但也存在一些性能损失。 三、Using 语句的使用 Using ...
在这个过程中,我们首先通过`EXECUTE IMMEDIATE`语句获取序列当前的下一个值,然后计算出需要的增量并更新序列的`INCREMENT BY`属性。之后,再次调用`NEXTVAL`确保序列值得到更新,并最后将`INCREMENT BY`属性重置为...
动态SQL的实现主要通过两种方法:直接执行(EXECUTE IMMEDIATE)和PREPARE/EXECUTE组合。下面将详细讲解这两种方法及其应用。 1. 直接执行(EXECUTE IMMEDIATE): 这种方式是直接将SQL语句作为字符串传递给数据库...
在 Oracle 中,`EXECUTE IMMEDIATE` 是一种常用的执行动态 SQL 的方式。下面通过几个示例来具体说明: 1. **执行 DML 语句** ```plsql DECLARE n_deptno NUMBER := 20; BEGIN EXECUTE IMMEDIATE 'SELECT ...
在 PL/SQL 中,可以使用 `EXECUTE IMMEDIATE` 语句来执行动态 SQL。 #### 二、动态 SQL 的执行方式 动态 SQL 在 Oracle 中有两种常见的执行方式: 1. **使用 EXECUTE IMMEDIATE:** - **DDL(数据定义语言)操作...
动态SQL的核心在于`EXECUTE IMMEDIATE`语句,这使得开发者能够在不知道具体SQL结构或者需要根据运行时的条件来决定SQL行为的情况下编写代码。 在动态SQL中,`EXECUTE IMMEDIATE`的使用方式主要有以下几种: 1. **...