简述

决策结构需要程序员指定一个或多个条件要计算,或由程序进行测试,如果条件被确定为真那么一条或多条语句被执行,如果要被执行的其它语句条件被确定为假,则选其它执行块。

PL/SQL编程语言提供了以下几种类型的决策语句

语句 描述

IF - THEN 语句 IF语句关联的条件通过THEN和END IF关键字封闭的语句序列。 如果条件为真,则语句被执行,如果条件为假或NULL,则IF语句什么都不做
IF-THEN-ELSE 语句 IF语句添加关键字ELSE后面的语句的替代序列。如果条件为假或NULL,语句则只有替换序列得到执行。它确保任一陈述的序列的被执行
IF-THEN-ELSIF 语句 它可以在几个方案之间进行选择
Case 语句 像IF语句中,CASE语句选择要执行的语句一个序列。但是选择顺序,CASE语句使用一个选择而不是多个布尔表达式。一个选择器其值被用来选择多个选项之一的表达式
Searched CASE 语句 所搜索的CASE语句没有选择,它的WHEN子句包含产生布尔值的搜索条件
内嵌IF-THEN-ELSE 可以使用一个IF-THEN或IF-THEN-ELSIF语句中的另一个IF-THEN或IF-THEN-ELSIF声明

IF-THEN语句

  1. IF (a <= 20) THEN
  2. b:= b+1;
  3. END IF;

IF-THEN-ELSE语句

  1. IF 1 = 2 THEN
  2. dbms_output.put_line('1 = 2')
  3. ELSE
  4. dbms_output.put_line('1 <> 2');
  5. END IF;

IF-THEN-ELSIF语句

使用IF-THEN-ELSIF语句时有几点要牢记。

它是ELSIF, 而不是 ELSEIF

一个IF-THEN语句可以有零或一个ELSE语句,它必须跟从ELSIF语句。

一个IF-THEN语句可以有0到多个ELSIF,它们必须在ELSE之前。

一旦某个ELSIF成功,任何剩余的ELSIF或其他都不被测试。

  1. DECLARE
  2. a number(3) := 66;
  3. BEGIN
  4. IF ( a = 6 ) THEN
  5. dbms_output.put_line('Value of a is 6' );
  6. ELSIF ( a = 66 ) THEN
  7. dbms_output.put_line('Value of a is 66' );
  8. ELSIF ( a = 666 ) THEN
  9. dbms_output.put_line('Value of a is 666' );
  10. ELSE
  11. dbms_output.put_line('the values is matching');
  12. END IF;
  13. dbms_output.put_line('the value of a is: ' || a );
  14. END;

CASE语句

  1. set serveroutput on
  2. DECLARE
  3. grade CHAR(1) := '&Guess';
  4. BEGIN
  5. CASE grade
  6. when 'A' then dbms_output.put_line('AA');
  7. when 'B' then dbms_output.put_line('BB');
  8. when 'C' then dbms_output.put_line('CC');
  9. when 'D' then dbms_output.put_line('DD');
  10. when 'E' then dbms_output.put_line('EE');
  11. else dbms_output.put_line('No such grade');
  12. END CASE;
  13. END;

搜索CASE语句

  1. CASE
  2. WHEN selector = 'value1' THEN S1;
  3. WHEN selector = 'value2' THEN S2;
  4. WHEN selector = 'value3' THEN S3;
  5. ...
  6. ELSE Sn; -- default case
  7. END CASE;

嵌套IF-THEN-ELSE语句

  1. DECLARE
  2. a number(3) := 100;
  3. b number(3) := 200;
  4. BEGIN
  5. IF( a = 100 ) THEN
  6. IF( b = 200 ) THEN
  7. dbms_output.put_line('Value of a is 100 and b is 200' );
  8. END IF;
  9. END IF;
  10. dbms_output.put_line('Exact value of a is : ' || a );
  11. dbms_output.put_line('Exact value of b is : ' || b );
  12. END;

(五)PL/SQL条件控制的更多相关文章

  1. PL/SQL 条件控制

    ------ PL/SQL 条件控制 IF-THEN语句 DECLARE a ) :; BEGIN a:; -- check the boolean condition using if statem ...

  2. PL\SQL结构控制、异常

    PL\SQL结构控制    1.IF条件控制语句(三种基本方式+IF语句的嵌套使用)        (1)IF...        (2)IF...ELSE        (3)IF...ELSIF. ...

  3. PL/SQL 使用控制流程

    一.条件分支语句 1.if判断 IF <布尔表达式> THEN PL/SQL 和 SQL语句 END IF; 2.if else判断 IF <布尔表达式> THEN PL/SQ ...

  4. PL/SQL 条件控制语句

    1.if-then 语句 语法: IF 条件 THEN 语句序列; END IF; 实例: DECLARE i ) :; BEGIN THEN dbms_output.put_line('True') ...

  5. oracle 树状结构递归 PL/SQL输出控制 包括空格输出控制

    树状结构 存储过程中通过递归构建,类似BBS回帖显示,代码共三段: 建表,插入数据,创建存储过程显示: 1.create table article(id number primary key,con ...

  6. SQL记录-PLSQL条件控制

    PL/SQL条件控制   决策结构需要程序员指定一个或多个条件要计算,或由程序进行测试,如果条件被确定为真那么一条或多条语句被执行,如果要被执行的其它语句条件被确定为假,则选其它执行块. 以下是从在大 ...

  7. PL/SQL 游标的使用

     游标的使用 ①游标概念 为了处理SQL 语句,ORACLE 必须分配一片叫上下文( context area )的区域来处理所必需的信息, 当中包含要处理的行的数目.一个指向语句被分析以后的表示 ...

  8. PL/SQL -->隐式游标(SQL%FOUND)

    PL/SQL -->隐式游标(SQL%FOUND) 分类: SQL/PLSQL 基础2010-12-22 16:23 4084人阅读 评论(0) 收藏 举报 sqlexceptionoracle ...

  9. Oracle学习DaySix(PL/SQL续)

    一.游标 在 PL/SQL 程序中,对于处理多行记录的事务经常使用游标来实现.游标是一个指向上下文的句柄( handle)或指针.通过游标,PL/SQL 可以控制上下文区和处理语句时上 下文区会发生些 ...

随机推荐

  1. POI2014 FAR-FarmCraft 树形DP+贪心

    题目链接 https://www.luogu.org/problem/P3574 题意 翻译其实已经很明确了 分析 这题一眼就是贪心啊,但贪心的方法要思索一下,首先是考虑先走时间多的子树,但不太现实, ...

  2. Spring Boot 完整讲解

    SpringBoot学习笔记 文章写得比较详细,所以很长(105336 字数),可以参考目录 文章目录 SpringBoot学习笔记 @[toc] 一. Spring Boot 入门 预:必须掌握的技 ...

  3. Java基础知识2-Java基本语法

    数据类型 1.Java程序的基本组成 关键字:被Java语言赋予特定含义的单词,不能作标识符,如private. 标识符:由数字.字母.$和_组成的字符串,用于引用变量.且首字母不能是数字. 变量:程 ...

  4. 邮件服务TLS/SSL,CA证书

     邮件服务TLS/SSL,CA证书 案例1:OpenSSL及证书服务 案例2:邮件TLS/SSL加密通信 1 案例1:OpenSSL及证书服务 1.1 问题 本案例要求熟悉OpenSSL工具的基本使用 ...

  5. C++ namespace 命名空间

    namespace即"命名空间",也称"名称空间" 那么这个 "名称空间" 是干啥的呢? 我们都知道,C/C++中的作用域可以由一个符号 { ...

  6. Linux 权限管理篇(一)

    可读        r 可写        w 可执行        x 档案属性: 第一栏:执行list -al后第一栏的十个标志[1 - 10] 1: d    目录 -    档案 l    连 ...

  7. Linux 系统篇(一)

    退出当前程序    quit 填充代码:    tab键 中断当前操作:    ctrl + c 键盘输入结束    ctrl + d 关机        shutdown 重启        reb ...

  8. Vue项目添加动态浏览器头部title

    0. 直接上 预览链接 + 效果图 Vue项目添加动态浏览器头部title 1. 实现思路 ( 1 ) 从路由router里面得到组件的title ( 2 ) title存vuex (本项目已经封装h ...

  9. Java编程最差实践常见问题详细说明(2)转

    Java编程最差实践常见问题详细说明(2)转 2012-12-13 13:57:20|  分类: JAVA |  标签:java  |举报|字号 订阅     反射使用不当  错误的写法: Java代 ...

  10. 浅谈ArrayList

    浅谈ArrayList 废话不多说(事实是不会说),让我们直接进入正题 首先讲一讲最基本的ArrayList的初始化,也就是我们常说的构造函数,ArrayList给我们提供了三种构造方式,我们逐个来查 ...