本章主要讨论 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. MVVM和MVC的区别,以及MVVM的缺点

    MVVM和MVC的区别 MVC和MVVM的区别其实并不大.都是一种设计思想. 主要就是MVC中Controller演变成MVVM中的viewModel. MVVM主要解决了MVC中大量的DOM操作使页 ...

  2. (转)intellij idea svn 修改文件后,父文件夹也标注修改

    svn文件修改后,默认只有当前文件更改而父文件没有标注,很不直观:查了一顿后,发现,可以设置: File—->settings—->version control—–>勾选show ...

  3. (转)Linux下内存映射文件的用法简介

    简介: 内存映射文件与虚拟内存有些类似,通过内存映射文件可以保留一个地址空间的区域,同时将物理存储器提交给此区域,只是内存文件映射的物理存储器来自一个已经存在于磁盘上的文件,而非系统的页文件,而且在对 ...

  4. DevExpress 项目目录列表参考(收集的 350个cs project)

    DevExpress.ExpressApp.Tools\DBUpdater\DBUpdater.csproj DevExpress.BonusSkins\DevExpress.BonusSkins.c ...

  5. iOS7重磅推新--不断尝试与重新设计的过程

    来源:GBin1.com iOS7重磅推新--不断尝试与重新设计的过程 或许你心里已经有了关于iPhone最新操作系统的评价,可能你喜欢它,也可能不喜欢,事实上大多数设计者不喜欢.设计界似乎一致认为I ...

  6. escape(s, t)函数的实现

    https://item.taobao.com/item.htm? spm=686.1000925.0.0.9TTLHO&id=535006878999 <span style=&quo ...

  7. Hello Socket - 第一个Socket程序

    1. 首先,要编写windows下socket程序,必须要加入Winsock支持 2. 服务端监听程序(Server.cpp) #include<winsock2.h> //包含头文件 # ...

  8. C++实现对数学基本运算表达式的解析

    代码地址如下:http://www.demodashi.com/demo/11078.html 前段时间在LeetCode上刷题,遇到了很多涉及对字符串进行解析的题目.可能是出于这个原因,最近迷恋上了 ...

  9. 0基础的小白怎么学习Java?

    自身零基础,那么我们应该先学好Java,首先我们来了解下Java的特性: Java语言是简单的 Java语言的语法与C语言和C++语言很接近,使得大多数程序员很容易学习和使用Java.另一方面,Jav ...

  10. CI框架下nginx重写规则

    因为: server { listen ; server_name 222.73.130.124; location / { index index.html index.htm index.php; ...