微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

oracle中rownum 与游标的处理

oracle

create or replace function getYwzt(var_ywwid varchar2,var_ywbh varchar2)

return varchar2
is
ywzt varchar2(2);
cursor cur_ywzt is
select rownum,inner_t.swclzt from(
select swclzt from zc_sqfq where ywwid=var_ywwid and ywbh like var_ywbh||'%' order by sfsqjs asc
) inner_t where rownum='1';
begin
FOR ywztList IN cur_ywzt LOOP
ywzt:=ywztList.swclzt;
EXIT WHEN cur_ywzt%NOTFOUND;
END LOOP;
RETURN ywzt;

end;


MysqL


begin DECLARE ywzt varchar(2); declare done int default false; declare r decimal(65,0); DECLARE cur_ywzt cursor for select @rownum:=@rownum+1 rownum,inner_t.swclzt from (SELECT @rownum:=0) r,( select swclzt from zc_sqfq where ywwid=var_ywwid and ywbh like var_ywbh||'%' order by sfsqjs asc ) inner_t limit 1; -- 指定游标循环结束时的返回值 declare continue HANDLER for not found set done = true; -- 打开游标 open cur_ywzt; -- 开始循环游标里的数据 read_loop:loop -- 根据游标当前指向的一条数据 fetch cur_ywzt into r,ywzt; -- 判断游标的循环是否结束 if done then leave read_loop; -- 跳出游标循环 end if; -- 结束游标循环 end loop; -- 关闭游标 close cur_ywzt; RETURN ywzt; end

原文地址:https://www.jb51.cc/oracle/208795.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐