分享
 
 
 

PL/SQL流程控制

王朝mssql·作者佚名  2008-05-21
窄屏简体版  字體: |||超大  

PL/SQL程序中的流程控制语句借鉴了许多高级语言的流程控制思想,但又有自己的特点。

条件控制

下面通过实例介绍条件控制语句的使用。

1. if..then..end if条件控制

采用if..then..end if条件控制的语法结构如图9.15所示。

在【SQLPlus Worksheet】中执行下列PL/SQL程序,该程序判定两个整数变量的大小。 执行结果如图9.16所示。

―――――――――――――――――――――――――――――――――――――

set serveroutput on

declare

number1 integer:=90;

number2 integer:=60;

begin

if number1>=number2 then

dbms_output.put_line('number1大于等于number2');

end if;

end;

―――――――――――――――――――――――――――――――――――――

【配套程序位置】:第9章\ conditioncontrol1.sql。

2. if..then..else..end if条件控制

采用if..then..else..end if条件控制的语法结构如图9.17所示。

在【SQLPlus Worksheet】中执行下列PL/SQL程序,该程序判定两个整数变量的大小,输出不同的结果。执行结果如图9.18所示。

―――――――――――――――――――――――――――――――――――――

set serveroutput on

declare

number1 integer:=80;

number2 integer:=90;

begin

if number1>=number2 then

dbms_output.put_line('number1大于等于number2');

else

dbms_output.put_line('number1小于number2');

end if;

end;

―――――――――――――――――――――――――――――――――――――

【配套程序位置】:第9章\ conditioncontrol2.sql。

3. if嵌套条件控制

采用if嵌套条件控制的语法结构如图9.19所示。

在【SQLPlus Worksheet】中执行下列PL/SQL程序,该程序判定两个整数变量的大小,输出不同的结果。

执行结果如图9.20所示。

―――――――――――――――――――――――――――――――――――――

set serveroutput on

declare

number1 integer:=80;

number2 integer:=90;

begin

if number1<=number2 then

if number1=number2 then

dbms_output.put_line('number1等于number2');

else

dbms_output.put_line('number1小于number2');

end if;

else

dbms_output.put_line('number1大于number2');

end if;

end;

―――――――――――――――――――――――――――――――――――――

【配套程序位置】:第9章\ conditioncontrol3.sql。

循环控制

循环结构是按照一定逻辑条件执行一组命令,PL/SQL中有4种基本循环结构,在它们基础上又可以演变出许多嵌套循环控制,这里介绍最基本的循环控制语句。

1. loop..exit..end loop循环控制

采用loop..exit..end loop循环控制的语法结构如图9.21所示。

在【SQLPlus Worksheet】中执行下列PL/SQL程序,该程序将number1变量每次加1,一直到等于number2为止,统计输出循环次数。

―――――――――――――――――――――――――――――――――――――

set serveroutput on

declare

number1 integer:=80;

number2 integer:=90;

i integer:=0;

begin

loop

number1:=number1+1;

if number1=number2 then

exit;

else

i:=i+1;

end if;

end loop;

dbms_output.put_line('共循环次数:'to_char(i));

end;

―――――――――――――――――――――――――――――――――――――

执行结果如图9.22所示。

【配套程序位置】:第9章\loopcontrol1.sql。

2. loop..exit..when..end loop循环控制

采用loop..exit..when..end loop循环控制的语法结构与图9.21所示结构类似。

exit when实际上就相当于

if 条件 then

exit;

end if;

在【SQLPlus Worksheet】中执行下列PL/SQL程序,该程序将number1变量每次加1,一直到等于number2为止,统计输出循环次数。

―――――――――――――――――――――――――――――――――――――

set serveroutput on

declare

number1 integer:=80;

number2 integer:=90;

i integer:=0;

begin

loop

number1:=number1+1;

i:=i+1;

exit when number1=number2;

end loop;

dbms_output.put_line('共循环次数:'to_char(i));

end;

―――――――――――――――――――――――――――――――――――――

执行结果如图9.23所示。

【配套程序位置】:第9章\loopcontrol2.sql。

when循环控制结束条件比采用if的条件控制结束循环次数多1次。

3. while..loop..end loop循环控制

采用loop..exit..when..end loop循环控制的语法如下。

while 条件 loop

执行语句段;

end loop;

在【SQLPlus Worksheet】中执行下列PL/SQL程序,该程序将number1变量每次加1,一直到等于number2为止,统计输出循环次数。

―――――――――――――――――――――――――――――――――――――

set serveroutput on

declare

number1 integer:=80;

number2 integer:=90;

i integer:=0;

begin

while number1<number2 loop

number1:=number1+1;

i:=i+1;

end loop;

dbms_output.put_line('共循环次数:'to_char(i));

end;

―――――――――――――――――――――――――――――――――――――

执行结果如图9.24所示。

【配套程序位置】:第9章\whilecontrol.sql。

4. for..in..loop..end循环控制

采用for..in..loop..end循环控制的语法如下。

for 循环变量 in [reverse] 循环下界..循环上界 loop

循环处理语句段;

end loop;

在【SQLPlus Worksheet】中执行下列PL/SQL程序,该程序通过循环变量I来控制number1增加次数,输出结果。执行结果如图9.25所示。

―――――――――――――――――――――――――――――――――――――

set serveroutput on

declare

number1 integer:=80;

number2 integer:=90;

i integer:=0;

begin

for i in 1..10 loop

number1:=number1+1;

end loop;

dbms_output.put_line('number1的值:'to_char(number1));

end;

―――――――――――――――――――――――――――――――――――――

【配套程序位置】:第9章\forcontrol.sql。

PL/SQL流程控制" /

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有