Oracle-存储过程 有入参和返回值

样例代码
传入V_PATIENT_CODE; 返回查找到的第一条数据

CREATE OR REPLACE PROCEDURE SKINTEST_RESULT
(
   V_PATIENT_CODE IN varchar2,-- IN 表示输入 后面写类型
   V_ST_RESULT OUT sys_refcursor -- OUT 表示返回值 后面写类型
)
AS
BEGIN
	-- open 表示打开游标,然后写循环
	OPEN V_ST_RESULT FOR  
	-- 一个查询语句 有;结尾
      SELECT * FROM 
      (
          SELECT A.* 
          FROM SKINTEST_INFO A 
          WHERE A.STATUS = 1
          AND A.PATIENT_CODE = V_PATIENT_CODE
      ) WHERE ROWNUM =1;
END;

注释:sys_refcursor 是游标,概念类似C中的指针,配合open通过指针后移遍历数据;如果是做过程内遍历的话常用cursor

存储过程里还常用if-elseif以及内部的foreach结构,后续用到会写样例记录

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值