DECODE 与CASE WHEN 的比较以及用法

Posted 公子苏苏苏

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DECODE 与CASE WHEN 的比较以及用法相关的知识,希望对你有一定的参考价值。

1.DECODE 只有Oracle 才有,其它数据库不支持;
2.CASE WHEN的用法, Oracle、SQL Server、 mysql 都支持;
3.DECODE 只能用做相等判断,但是可以配合sign函数进行大于,小于,等于的判断,CASE when可用于=,>=,<,<=,<>,is null,is not null 等的判断;
4.DECODE 使用其来比较简洁,CASE 虽然复杂但更为灵活;
5.另外,在decode中,null和null是相等的,但在case when中,只能用is null来判断,示例如下:
emp表中有一列comm,如果这列为null,则显示为0,否则,显示为原值:

用法

CASE WHEN:

单条件

CASE 
WHEN  MAIL_FLAG = ‘1‘  THEN  ‘已发放‘
WHEN  MAIL_FLAG = ‘0‘  THEN  ‘未发放‘

ELSE   ‘‘
END AS MAIL_FLAG

多条件

CASE 
WHEN  MAIL_FLAG = ‘1‘  AND  STATUS = ‘1‘  THEN  ‘已发放‘ 
WHEN  MAIL_FLAG = ‘0‘  AND  STATUS = ‘0‘  THEN  ‘未发放‘

ELSE   ‘‘
END AS MAIL_FLAG

 

DECODE:

DECODE(MAIL_FLAG,‘1‘,‘已导出‘,‘0‘,‘未导出 ‘ ) AS  MAIL_FLAG

DECODE(条件,值1,返回值1,值2,返回值2.....)

条件=值1 返回值1

条件=值2 返回值2

...........................

以上是关于DECODE 与CASE WHEN 的比较以及用法的主要内容,如果未能解决你的问题,请参考以下文章

SQL中的decode及case when的用法

case when 和 decode 的比较分析

decode用法

case...when...和decode——oracle

decode与case when

oracle case的这种写法怎么对应多个值 case x when……