PL/SQL 002---PL/SQL的基本能概念--2.2语言特性--2.2.3程序控制语句

2.2.3程序控制语句

机构化程序设计语言分顺序、循环、分支3中结构,PL/SQL提供了一系列的控制和跳转语句来支持这3种结构。

1.条件控制语句
最常用的是IF-THEN-ELSE语句,IF用来检查指定表达式的条件:THEN在条件中的值为True时执行代码:ELSE在条件值为FalseNULL时执行代码。在IF条件中可以使用布尔表达式包含多个条件,也可以使用IF-THEN-ELSIF语句来进行多条件判断。

如果要判断的条件过多,可以使用CASE语句,CASE语句可以仅检查一次条件判断的值,然后判断这个值在多种条件下的实现。

create or replace function getMarkByCaseWhen(score in number) --传入学生成绩

 return  varchar2 is  --返回绩点
  v_mark varchar2(2);
begin

  case
    when score > 90 then  --根据成绩进行判断
      v_mark := 'A';
    when score > 80 then
      v_mark := 'B';
    when score > 70 then
      v_mark := 'C';
    when score >= 60 then
      v_mark := 'D';
    when score < 60 then
      v_mark := 'F';
    
  end case;
  return v_mark;
end;

代码使用了CASE-WHEN语句后,在调用时与IF-THEN-ELSE能产生相同的效果,但是两者有一个区别:当CASE发现一个when**子句不存在判断条件时,会触发异常。

2.循环控制语句
PL/SQL 提供了三种类型的循环,如下所示:
(1)简单循环:这是最基础的循环类型,包含LOOP-END LOOP和用来退出循环的EXIT方法。
(2)数字FOR式循环:将会循环指定次数退出循环。
(3)WHILE循环:仅当条件成立时才执行循环。
以下展示如何使用数字式FOR循环打印九九乘法口诀表,定义代码如下:

--通过循环打印输出九九乘法表

    
declare
  --定义外层循环数
  v_num1 number;
  --定义内层循环数
  v_num2 number;
begin
  --第一层循环
  for v_num1 in 1 .. 9 loop
     --第二层循环从1开始到第一层结束
      for v_num2 in 1 .. v_num1 loop
        dbms_output.put(v_num2 
                        ||'*'
                        || v_num1
                        ||'='
                        ||v_num1*v_num2
                        ||'  '
        
        );
        end loop;
        dbms_output.put_line('');
  end loop;

end;


结果
在这里插入图片描述

为了打印九九乘法口诀表,使用了两个FOR循环,内层FOR根据外层FOR的循环次数来决定最大的计数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值