PL/SQL - 嵌套的 IF-THEN-ELSE 语句

在 PL/SQL 编程中嵌套 IF-ELSE 语句始终是合法的,这意味着您可以在其中使用一个 IFELSE IF 语句中嵌套另一个 IFELSE IF 语句。


语法

IF( boolean_expression 1)THEN 
   -- 当布尔表达式 1 为真时执行
   IF(boolean_expression 2) THEN 
      -- 当布尔表达式 2 为真时执行
      sequence-of-statements; 
   END IF; 
ELSE 
   -- 当布尔表达式 1 不为真时执行
   else-statements; 
END IF; 

示例

DECLARE 
   a number(3) := 100; 
   b number(3) := 200; 
BEGIN 
   -- 检查布尔条件
   IF( a = 100 ) THEN 
   -- 如果条件为真,则检查以下内容
      IF( b = 200 ) THEN 
      -- 如果条件为真,则打印以下内容
      dbms_output.put_line('Value of a is 100 and b is 200' ); 
      END IF; 
   END IF; 
   dbms_output.put_line('Exact value of a is : ' || a ); 
   dbms_output.put_line('Exact value of b is : ' || b ); 
END; 
/ 

在 SQL 提示符下执行上述代码时,会产生以下结果 −

Value of a is 100 and b is 200 
Exact value of a is : 100 
Exact value of b is : 200  

PL/SQL procedure successfully completed. 

❮ PL/SQL 条件