Oracle CASE WHEN 用法介绍

转载 2013年12月05日 15:32:42

http://www.cnblogs.com/eshizhan/archive/2012/04/06/2435493.html

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

复制代码
--简单Case函数  

CASE sex  
WHEN '1' THEN ''  
WHEN '2' THEN ''  
ELSE '其他' END  

--Case搜索函数  

CASE
WHEN sex = '1' THEN ''  
WHEN sex = '2' THEN ''  
ELSE '其他' END  
复制代码

 

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

2.1 SELECT CASE WHEN 用法

复制代码
SELECT   grade, COUNT (CASE WHEN sex = 1 THEN 1      /*sex 1为男生,2位女生*/
                       ELSE NULL
                       END) 男生数,
                COUNT (CASE WHEN sex = 2 THEN 1
                       ELSE NULL
                       END) 女生数
    FROM students GROUP BY grade;
复制代码

 

2.3 WHERE CASE WHEN 用法

复制代码
SELECT T2.*, T1.*
   FROM T1, T2
  WHERE (CASE WHEN T2.COMPARE_TYPE = 'A' AND
                   T1.SOME_TYPE LIKE 'NOTHING%'
                THEN 1
              WHEN T2.COMPARE_TYPE != 'A' AND
                   T1.SOME_TYPE NOT LIKE 'NOTHING%'
                THEN 1
              ELSE 0
           END) = 1
复制代码

 

2.4 GROUP BY CASE WHEN 用法

复制代码
SELECT  
CASE WHEN salary <= 500 THEN '1'  
WHEN salary > 500 AND salary <= 600  THEN '2'  
WHEN salary > 600 AND salary <= 800  THEN '3'  
WHEN salary > 800 AND salary <= 1000 THEN '4'  
ELSE NULL END salary_class, -- 别名命名
COUNT(*)  
FROM    Table_A  
GROUP BY  
CASE WHEN salary <= 500 THEN '1'  
WHEN salary > 500 AND salary <= 600  THEN '2'  
WHEN salary > 600 AND salary <= 800  THEN '3'  
WHEN salary > 800 AND salary <= 1000 THEN '4'  
ELSE NULL END;  
复制代码

 

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

3.1 DECODE() 函数

select decode(sex, 'M', 'Male', 'F', 'Female', 'Unknown')
from   employees;

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

3.2 在WHERE中特殊实现

SELECT T2.*, T1.*
   FROM T1, T2
  WHERE (T2.COMPARE_TYPE = 'A' AND T1.SOME_TYPE LIKE 'NOTHING%')
         OR
        (T2.COMPARE_TYPE != 'A' AND T1.SOME_TYPE NOT LIKE 'NOTHING%')

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

Oracle CASE WHEN 用法介绍

Oracle CASE WHEN 用法介绍 1. CASE WHEN 表达式有两种形式 --简单Case函数 CASE sex WHEN '1' THEN '男' ...

oracle case when 用法总结 (转)

ORACLE CASE WHEN 及 SELECT CASE WHEN的用法   Case具有两种格式。简单Case函数和Case搜索函数。 Sql代码   ...

Oracle中CASE WHEN的用法实例

实例演示:   (1)查询表users中的数据。   select u.id,u.realname,U.SEX from users u;   查询结果如下   ID    REALNAME ...
  • jkaies
  • jkaies
  • 2013年08月08日 13:53
  • 364

Oracle中的case when then 用法.

case when then 多条件判断 博客分类: sql SQL CASE     WHEN 条件1 THEN 结果1     WHEN 条件2 THEN 结果2     ...

CASE WHEN 用法介绍2

http://www.cnblogs.com/eshizhan/archive/2012/04/06/2435493.html Oracle CASE WHEN 用法介绍 1. C...

mysql中case when用法与及注意事项

CASE 计算条件列表并返回多个可能结果表达式之一。 CASE 具有两种格式: 简单 CASE 函数将某个表达式与一组简单表达式进行比较以确定结果。 CASE 搜索函数计算一组布尔表达式以...

SQL中Case When 用法举例

Case具有两种格式。简单Case函数和Case搜索函数。 --简单Case函数 CASE sex  WHEN '1' THEN '男'  WHEN '2' THEN '女'  ELSE '其他' E...

case when和decode的用法与区别

一、case when case when 类似我们的if ...else ,判断语句 语法如下: CASE expr WHEN expr1 THEN return_expr1        ...

SQL中的CASE WHEN用法 .

SQL中Case的使用方法     Case具有两种格式。简单Case函数和Case搜索函数。    --简单Case函数     CASE sex              WHEN '1' THE...
  • lchwhy
  • lchwhy
  • 2011年11月13日 10:23
  • 233

sql语句判断 case when用法(二)

sql语句判断方法之一 select case when t.bk1='on' then 1 else 0 end  as 基础 , case when t.bk2='on' then 1...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Oracle CASE WHEN 用法介绍
举报原因:
原因补充:

(最多只允许输入30个字)