oracle存储过程中应用动态sql

本文介绍如何使用存储过程来优化数据库操作,减少网络连接开销。详细解释了创建存储过程的语法,动态SQL的概念及其实现方法,包括执行删除操作和返回结果集的技术细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求背景:对有些数据库操作较多的功能算法需求,或使用应用程序代码多次连接操作数据,会造成较大性能损耗,或者系统动态参数化如要查询的表名是存在数据库里的,为节减网络连接开销,建议使用存储过程实现数据库操作需求的算法。动态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;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值