oracle 存储过程心得2

来源:互联网 发布:手机撒谎软件下载 编辑:程序博客网 时间:2024/06/05 04:33

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

LOOPif 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)isbegin  ……  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 procedure pro_hy_data_handle_recordas……  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了
原创粉丝点击