oracle存储过程中应用动态sql
2010-09-17 01:33
381 查看
需求背景:对有些数据库操作较多的功能算法需求,或使用应用程序代码多次连接操作数据,会造成较大性能损耗,或者系统动态参数化如要查询的表名是存在数据库里的,为节减网络连接开销,建议使用存储过程实现数据库操作需求的算法。动态sql ,意思是sql语句并不是事先明确的,而是可根据参数变化的,通常是我们在存储过程中拼接生成sql字符串,并执行这个字符串返回结果。
1.创建存储过程语法:
CREATE OR REPLACE PROCEDURE 存储过程名称( 参数列表)
Is
变量定义;
Begin
逻辑实现;
End 存储过程名称;
例子:
CREATE OR REPLACE PROCEDURE GZGPORTAL.POSITION_JOB_PAY(
orgUnitLongNumber varchar2,
isSub char,
beginYearMonth varchar2,
endYearMonth varchar2,
isPosition char,
returnSet OUT sys_refcursor //返回值 ,游标类型,可用于返回结果集
)
IS
horTableName varchar2(30);
hisTableName varchar2(30);
insertSQL VARCHAR2(2000);
Begin
。。。。。
End POSITION_JOB_PAY ;
2.存储过程动态sql
sqlstr := 'delete t_temp_orgSecheme' ;
EXECUTE IMMEDIATE (sqlstr);
Commit;
3.执行动态sql 返回结果集
returnSet OUT sys_refcursor ; 定义返回值变量,游标类型
open returnSet for
select * from table;
return returnSet;
1.创建存储过程语法:
CREATE OR REPLACE PROCEDURE 存储过程名称( 参数列表)
Is
变量定义;
Begin
逻辑实现;
End 存储过程名称;
例子:
CREATE OR REPLACE PROCEDURE GZGPORTAL.POSITION_JOB_PAY(
orgUnitLongNumber varchar2,
isSub char,
beginYearMonth varchar2,
endYearMonth varchar2,
isPosition char,
returnSet OUT sys_refcursor //返回值 ,游标类型,可用于返回结果集
)
IS
horTableName varchar2(30);
hisTableName varchar2(30);
insertSQL VARCHAR2(2000);
Begin
。。。。。
End POSITION_JOB_PAY ;
2.存储过程动态sql
sqlstr := 'delete t_temp_orgSecheme' ;
EXECUTE IMMEDIATE (sqlstr);
Commit;
3.执行动态sql 返回结果集
returnSet OUT sys_refcursor ; 定义返回值变量,游标类型
open returnSet for
select * from table;
return returnSet;
相关文章推荐
- SQL的存储过程、动态语句、临时表、游标的综合应用
- 简单搞一下 Oracle 存储过程动态SQL之获取查询分页!
- oracle 动态SQL在存储过程中的使用
- Oracle 动态SQL语句(4)之存储过程的调用与浅谈字符串的使用
- Oracle 动态SQL语句(3)之保存存储过程
- oracle动态sql:存储过程中动态调用存储过程,并且动态调用的存储过程出参数游标
- oracle 存储过程执行动态sql返回游标
- Oracle 存储过程及函数中游标+动态的sql处理
- Oracle 存储过程中执行动态SQL,动态表名
- oracle存储过程执行动态sql
- oracle 在存储过程中定义动态sql
- oracle 调用动态存储过程,动态sql
- oracle execute immediate 动态执行SQL存储过程
- ORACLE 包内的存储过程的动态sql
- sql server、db2、oracle 存储过程动态sql语句示例
- oracle存储过程中如何执行动态SQL语句
- oracle存储过程中如何执行动态SQL语句
- oracle存储过程如何定义,动态判断条件sql如何书写
- ORACLE 包内的存储过程的动态sql
- 简单搞一下 Oracle 存储过程动态SQL之获取查询总数!