免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2043 | 回复: 3
打印 上一主题 下一主题

请教关于goto跳转标签的使用问题! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-03-23 18:40 |只看该作者 |倒序浏览
大家好:
    请问如何实现在PL/SQL程序中,当使用goto lab1语句时,才会执行<<lab1>>标签的代码,但是我测试发现,无论有无执行goto,都会执行<<lab1>>内的代码,这样就觉得使用goto失去了意义,如下代码所示:
SQL> declare
  2    v_count number:=0;
  3  begin
  4    for i in 1..3 loop
  5      v_count:=v_count+i;
  6      if v_count=10 then
  7        goto lab1;
  8      end if;
  9    end loop;
10    <<lab1>>
11      dbms_output.put_line('v_count=10了');
12  end;
13  /

v_count=10了

PL/SQL procedure successfully completed
-----
以上代码所示,当只有v_count=10 ,才会执行goto lab1;执行<<lab1>>内的代码,但是上面代码,明显不满足v_count=10,但是仍然会执行<<lab1>>内的代码,输出:“v_count=10了”。
请问如何实现在PL/SQL程序中,当使用goto lab1语句时,才会执行<<lab1>>标签的代码?
虽然知道使用goto语句会使程序变得混乱,思路不清晰,但觉得有时可能需要使用,了解一下也好,还望各位大侠协助解答,谢谢!

论坛徽章:
0
2 [报告]
发表于 2012-03-24 09:01 |只看该作者
有人可以帮忙解答下吗?非常感谢!

论坛徽章:
5
天蝎座
日期:2014-01-23 12:27:392015亚冠之德黑兰石油
日期:2015-05-14 13:33:042015年亚洲杯之乌兹别克斯坦
日期:2015-03-06 14:10:38天秤座
日期:2014-01-24 15:03:052015亚冠之德黑兰石油
日期:2015-08-27 13:43:58
3 [报告]
发表于 2012-03-26 17:02 |只看该作者
本帖最后由 moon38sun 于 2012-03-26 23:14 编辑

goto是改变执行顺序,不满足条件的时候,仍然顺序执行。
要是希望不满足条件的时候不执行,可以加一个条件判断,就可以了。
     if v_count!=10 then
        goto quit;
      end if;
    <<lab1>>
   dbms_output.put_line('v_count=10');
    <<quit>>
   null;

论坛徽章:
0
4 [报告]
发表于 2012-03-26 18:31 |只看该作者
楼上正
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP