本章主要讨论 case 语句

   1:  case [SELECTOR]
   2:    when expression 1 then statement 1;
   3:    when expression 2 then statement 2;
   4:    ...
   5:    when expression N then statement N;
   6:    else statement N+1;
   7:  end case;

注意: pl/sql 中的 case 没有 break;

   1:  declare
   2:      v_num        number := &sv_user_num;
   3:      v_num_flag    number;
   4:  begin
   5:      v_num_flage := mod(v_num, 2);
   6:      case v_num_flag
   7:          when 0 then
   8:              dbms_output.put_line(v_num || 'is even number');
   9:          else
  10:              dbms_output.put_line(v_num || 'is odd number');
  11:      end case;
  12:      dbms_output.put_line('Done');
  13:  end;
  14:  /
  15:  show errors;

注意: case 语句有两种形式,

1. 普通形式的 case 语句, 如上例 (有选择器, SELECTOR)

2. 搜索形式的 case 语句, 即 case 关键词后边没有跟表达式, 而是直接逻辑判断 when 后边的 expression , 如果为真就执行, 如下例子: (没有选择器, SELECTOR)

   1:  -- 不带选择器的(SELECTOR)CASE语句
   2:  declare
   3:      v_num        number := &sv_user_num;
   4:      v_num_flag    number;
   5:  begin
   6:      case 
   7:          when MOD(v_num, 2) = 0 then
   8:              dbms_output.put_line(v_num || 'is even number');
   9:          else
  10:              dbms_output.put_line(v_num || 'is odd number');
  11:      end case;
  12:      dbms_output.put_line('Done');
  13:  end;
  14:  /
  15:  show errors;

使用 case 表达式 (表达式一定要与变量对应)

   1:  -- case 表达式
   2:  declare
   3:      v_num        number := &sv_user_num;
   4:      v_num_flag     number;
   5:      v_result    varchar2(30);
   6:  begin
   7:      v_num_flag := mod(v_num, 2);
   8:      
   9:      v_result :=
  10:      case v_num_flag
  11:          when 0 then v_num || 'is even number'
  12:          else v_num || ' is odd number'
  13:      end;        -- 注意: 这只是 end, 而不是 end case
  14:      
  15:  end;
  16:  /
  17:  show errors;

BULLIF, COALESCE 函数

NULLIF(expression1, expression2), 如果 expression1 = expression2, 返回 null, 否则 返回 expression1. 这个函数与 NVL 函数相反

例如:

   1:  declare
   2:      v_num        number := &sv_user_num;
   3:      v_remainder    number;
   4:  begin
   5:      v_remainder := NULLIF(MOD(v_num, 2), 0);  -- 函数会返回值
   6:  end;
   7:  /
   8:  show errors;

COALESCE(expression1, expression2, …, expressionN), 若果expression1 是null, 就确认expression2, 如果expression2 也是null, 就确认expression3 以此类推, 直到一个不为null 的值. 如果所有的expression都是null, 那么这个函数就返回 null.

pl/sql 实例精解 05的更多相关文章

  1. pl/sql 实例精解 03

    1. 在Pl/sql 中使用 sql 1: /* 2: * 一个 pl/sql 语句块, 只是一个容器, 是表明一个整体的容器, 容器里可以放置多个sql语句 3: */ 4:   5: declar ...

  2. pl/sql 实例精解 04

    本章主要讨论, IF 语句的应用. 1: if condition1 then 2: statement1 3: elsif condition2 then 4: statement2 5: else ...

  3. ORACLE PL/SQL 实例精解之第六章 迭代控制之一

    6.1 简单循环 简单循环,就想其名称一张,是一种最基本循环.简单循环具有如下结构 LOOP STATEMENT 1; STATEMENT 2; ... STATEMENT N; END LOOP; ...

  4. ORACLE PL/SQL 实例精解之第三章 PL/SQL中的SQL

    3.1 在PL/SQL中使用DML 在PL/SQL语块中,两种变量赋值a. := 初始化.b. select into语法,PL/SQL语块的声明部分被声明的变量,后期可以使用选择语句进行赋值. 3. ...

  5. ORACLE PL/SQL 实例精解之第二章 通用编程语言基础

    通用编程语言基础 2.1PL/SQL编程基础 1. 字符类型:支持四中类型字符:字母,数字,符号和空格,组合一个或多个字符就会创建一个词汇单元 2. 词汇单元 a.标识符必须以字符开头 b.保留字是p ...

  6. ORACLE PL/SQL 实例精解之第一章 PL/SQL概念

    1.传统一层一层传数据,而PLSQL作为独立的单元返回客户端,减少查询,减少网路传输的往返,高效 2.PL/SQL语句块 分为两种:命名(子程序,函数,包保存在数据库中,后期可以根据名称进行引用),匿 ...

  7. pl/sql 实例精解 06

    1. 简单循环 1: LOOP 2: statement1; 3: statement2; 4: EXIT WHEN condition; 5: END LOOP; 6: statement3; 也可 ...

  8. pl/sql 实例精解 08

    1: EXCEPTION 2: WHEN EXCEPTION_NAME THEN 3: ERROR-PROCESSING STATEMENTS; 写在 begin 与 end 的之间的处理异常块. 常 ...

  9. pl/sql 实例精解 07

    这章主要讨论 oracle11g 新特性, continue, continue when 语句 continue 的作用同其他编程语言一样. continue when condition 只是当条 ...

随机推荐

  1. 区域设置 ID (LCID) 表, 及获取方法

    区域设置 ID (LCID) 表, 及获取方法 中国的区域设置 ID 是 2052, 如果经常打开微软软件的安装目录应该经常见到.获取很简单, 有现成的 API 函数: GetThreadLocale ...

  2. HTTP状态码具体解释

    HTTP状态码(HTTP Status Code)是用以表示网页serverHTTP响应状态的3位数字代码.它由 RFC 2616 规范定义的,并得到RFC 2518.RFC 2817.RFC 229 ...

  3. Spring Boot环境下自定义shiro过滤器会过滤所有的url的问题

    在配置shiro过滤器时增加了自定义的过滤器,主要是用来处理未登录状态下返回一些信息 //自定义过滤器 Map<String, Filter> filtersMap = new Linke ...

  4. java中的初始化块

    public class Person { int a=6;//声明实例变量制定默认值,也可以认为是对象的初始化代码,执行顺序与源代码中的排列顺序相同 { System.out.println(&qu ...

  5. CDN新应用和客户

    目前的CDN配置服务主要应用于证券.金融保险.ISP.ICP.网上交易.门户网站.大中型公司.网络教学等领域.另外在行业专网.互联网中都可以用到,甚至可以对局域网进行网络优化.利用CDN,这些网站无需 ...

  6. gensim自然语言处理(续)

    上一篇,已经实现了如何将一条语句在一个语料库中比较相似度, 发现运行的时候每次都要编译语料库,通过查找资料,可以一次性编译成预料库,存人文件 编译语料库代码 11_k.py import sysimp ...

  7. 算法笔记_163:算法提高 最大乘积(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 对于n个数,从中取出m个数,如何取使得这m个数的乘积最大呢? 输入格式 第一行一个数表示数据组数 每组输入数据共2行: 第1行给出总共的数 ...

  8. Excle中range的一些用法

    以下是一些range的简单用法 Sub aa() '-=============================================== '给B列设置填充颜色为黄色 Range(" ...

  9. 【前端】jQuery

    一.jQuery是什么? 1.jQuery由美国人John Resig创建,至今已吸引了来自世界各地的众多JavaScript高手加入其team 2.jQuery是继prototype之后有一个优秀的 ...

  10. Windows 10 KMS 激活方法

    本篇文章由:http://xinpure.com/windows-10-activate-method/ 摘抄: http://www.nruan.com/win-key.html 须知:如果需要在线 ...