Oracle case when 的使用方法

前端之家收集整理的这篇文章主要介绍了Oracle case when 的使用方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

文章转载自:http://www.cnblogs.com/eshizhan/archive/2012/04/06/2435493.html

1. CASE WHEN 表达式有两种形式

  1. --简单Case函数
  2.  
  3. CASE sex
  4. WHEN '1' THEN '
  5. 2ELSE 其他END
  6.  
  7. Case搜索函数 CASE
  8. WHEN sex = END

2. CASE WHEN 在语句中不同位置的用法

2.1 SELECT CASE WHEN 用法

  1. SELECT grade,COUNT (CASE = 1 THEN 1 /*sex 1为男生,2位女生*/
  2. ELSE NULL
  3. END) 男生数,0)">2 1
  4. NULL
  5. END) 女生数
  6. FROM students GROUP BY grade;

2.3 WHERE CASE WHEN 用法

  1. SELECT T2.*,T1.*
  2. FROM T1,T2
  3. WHERE (WHEN T2.COMPARE_TYPE A' AND
  4. T1.SOME_TYPE LIKE NOTHING%'
  5. 1
  6. != NOT ELSE 0
  7. END) 1

2.4 GROUP BY CASE WHEN 用法

  1. SELECT
  2. WHEN salary <= 500 > 500 AND salary 600 600 800 3800 1000 4NULL END salary_class, 别名命名
  3. COUNT(*)
  4. FROM Table_A
  5. BY
  6. END;

3.关于IF-THEN-ELSE的其他实现

3.1 DECODE() 函数

  1. select decode(sex,0)">M',0)">MaleFFemaleUnknown')
  2. from employees;

貌似只有Oracle提供该函数,而且不支持ANSI sql,语法上也没CASE WHEN清晰,个人不推荐使用。

3.2 在WHERE中特殊实现

  1. WHERE (T2.COMPARE_TYPE AND T1.SOME_TYPE ')
  2. OR
  3. (T2.COMPARE_TYPE ')

这种方法也是在特殊情况下使用,要多注意逻辑,不要弄错。

猜你在找的Oracle相关文章