oracle存储过程中应用动态sql

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

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值