网站/小程序/APP个性化定制开发,二开,改版等服务,加扣:8582-36016

这篇文章介绍了Oraclecase when函数的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下


一、case when 的基本用法见:

PL/SQL 使用控制流程

二、case when在select语句中的用法

SELECT grade, COUNT (CASE WHEN sex = 1 THEN 1   ELSE NULL   END) 男生数,
              COUNT (CASE WHEN sex = 2 THEN 1   ELSE NULL   END) 女生数
FROM students
GROUP BY grade;


1、在Case函数中,可以使用BETWEEN,LIKE,IS NULL,IN,EXISTS等。 

Case函数不同于DECODE函数。在Case函数中,可以使用BETWEEN,LIKE,IS NULL,IN,EXISTS等等。比如说使用IN,EXISTS,可以进行子查询,从而 实现更多的功能。

SELECT keyCol, CASE WHEN keyCol IN ( SELECT keyCol FROM tbl_B )  THEN 'Matched' ELSE 'Unmatched' END Label
FROM tbl_A;


也可以使用NOT IN和NOT EXISTS,但是这个时候要注意NULL的情况。 

2、根据条件有选择的UPDATE。

UPDATE PersonnelSET salary =
CASE WHEN salary >= 5000                   THEN salary * 0.9
     WHEN salary >= 2000 AND salary < 4600  THEN salary * 1.15
ELSE salary END;


三、case when在where语句中的用法 

SELECT * FROM   TB_Test
WHERE  stateid IN ( 10, 20 )
       AND ( CASE  WHEN stateid = 20 AND userid <> 2 THEN 0
                   ELSE 1
              END ) = 1


四、case when在group by 语句中的用法(不常用) 

SELECT
CASE WHEN salary <= 500 THEN '1'
WHEN salary > 500 AND salary <= 600  THEN '2'
WHEN salary > 600 AND salary <= 800  THEN '3'
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'
ELSE NULL END;


 


评论 0

暂无评论
0
0
0
立即
投稿
发表
评论
返回
顶部