Oracle中case|Oracle中case when函数的用法
一、case when 的基本用法见:
【Oracle中case|Oracle中case when函数的用法】PL/SQL 使用控制流程
二、case when在select语句中的用法
SELECT grade, COUNT (CASE WHEN sex = 1 THEN 1ELSE NULLEND) 男生数,COUNT (CASE WHEN sex = 2 THEN 1ELSE NULLEND) 女生数FROM studentsGROUP 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 >= 5000THEN salary * 0.9 WHEN salary >= 2000 AND salary < 4600THEN salary * 1.15 ELSE salary END;
三、case when在where语句中的用法
SELECT * FROMTB_TestWHEREstateid IN ( 10, 20 )AND ( CASEWHEN stateid = 20 AND userid <> 2 THEN 0ELSE 1 END ) = 1
四、case when在group by 语句中的用法(不常用)
SELECT CASE WHEN salary <= 500 THEN '1' WHEN salary > 500 AND salary <= 600THEN '2' WHEN salary > 600 AND salary <= 800THEN '3' ELSE NULL END salary_class, -- 别名命名COUNT(*)FROMTable_A GROUP BY CASE WHEN salary <= 500 THEN '1' WHEN salary > 500 AND salary <= 600THEN '2' WHEN salary > 600 AND salary <= 800THEN '3' ELSE NULL END;
到此这篇关于Oracle中case when函数用法的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
推荐阅读
- android中简单便捷使用GreenDao本地数据库及采坑之路
- 微信小程序中使用vant-weapp中时间控件默认显示每月1号
- R矩阵用法详解
- R编程中的关键字用法图解
- html中input的accept总结
- 解决 mpvue 项目使用 vant-weapp 组件库 Uploader 时其中的 after-read 方法回调函数调用不成功
- Android中网络框架的简单封装
- 使用APT实现Android中View的注入
- R If-else语句示例图解
- 如何加入工作组,图文详细说明如何加入工作组