Oracle   发布时间:2022-05-17  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了oracle 存储过程心得2大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

1、退出存储过程
return

if old_save_time = new_save_time then--没有最新数据,退出
    insert into hy_data_handle_mark(ID,save_time,mark_start,mark_finish) values(seq_hy_data_handle_mark.nextval,new_save_time,sysdate,sysdate);
    commit;
    return;
  end if;

2、退出循环
exit

begin open c_ID;
    LOOP
      FETCH c_ID INTO v_ID;
      EXIT WHEN c_ID%NOTFOUND;
      insert into tmp_cursor(ID) values(v_ID);
    END LOOP;  
    CLOSE c_ID;
  end;

3、退出当前循环
conTinue

LOOP
if min_time is null then conTinue;end if;--指定时间段内已处理
END LOOP

4、返回多个值
返回一个值用函数,超出一个,一般用存储过程

create or replace procedure PRO_OFFSET_TIME(v_station_code in nmemc.hy_station.station_code%TYPE,v_min_time date,v_max_time date,min_offset out number,max_offset out number) is begin …… if min_offset is null then min_offset:= 30/1440;--30分钟
  end if;

  if max_offset is null then
    max_offset:= 240/1440;--4小时
  end if;

end PRO_OFFSET_TIME;
/

调用:

reate or replace @H_419_144@procedure pro_hy_data_handle_record as …… @H_499_146@min_offset number:= 30/1440;--30分钟
  max_offset number:= 240/1440;--4小时
begin
……
pro_offset_time(v_station_code,k_min_time,k_max_time,min_offset,max_offset);
end;
--然后就可以直接使用min_offset,max_offset了

大佬总结

以上是大佬教程为你收集整理的oracle 存储过程心得2全部内容,希望文章能够帮你解决oracle 存储过程心得2所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:ssysdate