1. PL/SQL中的流控制
PL/SQL提供了丰富的流控制语句,用来对程序的执行流程进行控制。通过使用这些流控制语句,可以编写更复杂的PL/SQL块。流控制语句主要分为两类:条件判断语句和循环语句。
2. IF语句
基本介绍:
IF语句是一种条件判断语句,它根据条件判断的结果执行不同的代码。最简单的IF语句格式为:IF 条件 THEN 代码 END IF;
举例:
假设要判断一个数是否为正数,如果是正数则输出“该数是正数”:DECLARE num INTEGER := 10; BEGIN IF num > 0 THEN dbms_output.put_line('该数是正数'); END IF; END; /
IF-ELSE语句:
如果条件成立,则执行指定的代码;否则,执行IF语句后面的代码。格式如下:IF 条件 THEN 代码1 ELSE 代码2 END IF;
举例:
判断一个数是否为正数,如果是正数输出“该数是正数”,否则输出“该数是负数或零”:DECLARE num INTEGER := -5; BEGIN IF num > 0 THEN dbms_output.put_line('该数是正数'); ELSE dbms_output.put_line('该数是负数或零'); END IF; END; /
IF-ELSIF-ELSE语句:
在更复杂的情况下,要先后判断多个条件。格式如下:IF 条件1 THEN 代码1 ELSIF 条件2 THEN 代码2 ELSE 代码n END IF;
举例:
判断一个数的正负性,如果是正数输出“正数”,如果是负数输出“负数”,如果是零输出“零”:DECLARE num INTEGER := 0; BEGIN IF num > 0 THEN dbms_output.put_line('正数'); ELSIF num < 0 THEN dbms_output.put_line('负数'); ELSE dbms_output.put_line('零'); END IF; END; /
条件的联合:
可以通过AND和OR运算符连接多个条件进行判断。- AND运算:所有条件都成立时,整个条件判断才成立。
- OR运算:只要有一个条件成立,整个条件判断就成立。
举例:
判断一个数是否在10到20之间(包括10和20),如果是则输出“该数在范围内”,否则输出“该数不在范围内”:DECLARE num INTEGER := 15; BEGIN IF num >= 10 AND num <= 20 THEN dbms_output.put_line('该数在范围内'); ELSE dbms_output.put_line('该数不在范围内'); END IF; END; /
3. LOOP语句
基本介绍:
LOOP是一种循环语句,它使一部分代码反复执行。LOOP语句的基本格式为:LOOP 循环体 END LOOP;
EXIT语句:
EXIT语句用于退出LOOP循环,一般与IF语句结合使用。举例:
输出1到10的数字:DECLARE i INTEGER := 1; BEGIN LOOP dbms_output.put_line(i); i := i + 1; EXIT WHEN i > 10; END LOOP; END; /
复杂示例:
计算1+2+3+…+500的值,当和大于500时停止,求“累计算大于500的最后一个整数”:SET SERVEROUTPUT ON; DECLARE i INTEGER := 0; total INTEGER := 0; BEGIN LOOP i := i + 1; total := total + i; EXIT WHEN total > 500; END LOOP; dbms_output.put_line('累计算大于500的最后一个整数为:' || i); END; /
非常感谢您读到这里!如果您觉得这篇文章对您有帮助,可以关注一下博主。关注后,您将第一时间获得最新的AI、云计算、运维(Linux、数据库,容器等)技术,以及更多实用的技能干货。
无论你是AI新手还是AI专家,学习最前沿的AI技术,AI创富俱乐部你值得拥有!
本文由mdnice多平台发布
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。