度量快速开发平台-专业、快速的软件定制快开平台

标题: oracle中decode的用法简介 [打印本页]

作者: 张兴康    时间: 2020-4-4 17:46
标题: oracle中decode的用法简介
decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值)

该函数的含义如下:
IF 条件=值1 THEN
    RETURN(翻译值1)
ELSIF 条件=值2 THEN
    RETURN(翻译值2)
    ......
ELSIF 条件=值n THEN
    RETURN(翻译值n)
ELSE
    RETURN(缺省值)
END IF
decode(字段或字段的运算,值1,值2,值3)

       这个函数运行的结果是,当字段或字段的运算的值等于值1时,该函数返回值2,否则返回值3
当然值1,值2,值3也可以是表达式,这个函数使得某些sql语句简单了许多



作者: 张兴康    时间: 2020-4-4 17:46
比如要查询某班男生和女生的数量分别是多少?

通常我们这么写:

select count(*) from 表 where 性别 = 男;

select count(*) from 表 where 性别 = 女;

要想显示到一起还要union一下,太麻烦了

用decode呢,只需要一句话

select decode(性别,男,1,0),decode(性别,女,1,0) from 表
作者: 张兴康    时间: 2020-4-4 17:58
自顶一个
作者: 王爱东    时间: 2020-4-4 18:16
可以可以。这个和case when  then 差不多,但是代码简洁多了。
作者: 万望    时间: 2020-4-4 21:36
就是满足表达式的值,即返回一个值, 无匹配就会返回缺省的值
作者: 张军勇    时间: 2020-4-5 09:28
王爱东 发表于 2015-11-4 18:16
可以可以。这个和case when  then 差不多,但是代码简洁多了。

经常用的函数。
作者: 陈晓龙    时间: 2020-4-5 10:22
张兴康 发表于 2015-11-4 17:46
比如要查询某班男生和女生的数量分别是多少?

通常我们这么写:

好用!好强大!




欢迎光临 度量快速开发平台-专业、快速的软件定制快开平台 (http://bbs.delit.cn/) Powered by Discuz! X3.2