三分钟搞懂SQL的Case函数

简介: 三分钟搞懂SQL的Case函数

文章标题

前言

一: 使用语法

作用一: 结合分组统计数据

作用二: 分条件更新字段值

作用三: 检查表中字段值是否一致

作用四: 行转列(重点-面试常见)

五:普通case函数和搜索case函数的区别

六:总结

  温馨提示: 本文大约1832字,阅读完大概需要2-3分钟,希望您能耐心看完,倘若你对该知识点已经比较熟悉,你可以直接通过目录跳转到你感兴趣的地方,希望阅读本文能够对您有所帮助,如果阅读过程中有什么好的建议、看法,欢迎在文章下方留言或者私信我,如果觉的文章给你带来一点帮助,可以帮忙点一下赞和关注,谢谢!!

前言

作用: 可以使用它们在数据库进行判断功能,跟代码中的if…else功能一样.但是,它们又存在差异,下面就来讲它们的具体作用和差别。

一: 使用语法

  (一)普通case函数

CASE  <表达式>
   WHEN <值1> THEN <操作>
   WHEN <值2> THEN <操作>
   ...
   ELSE <操作>
END 

(一)搜索case函数

CASE
    WHEN <条件1> THEN <命令>
    WHEN <条件2> THEN <命令>
    ...
    ELSE commands
END

作用一: 结合分组统计数据

   需求: 将下图的数据按照"洲"进行统计总人数

image.png

(一)方式一: 使用普通的case函数进行统计

 

    select (
    case name 
      when '中国' then '亚洲'
      when '日本' then '亚洲'
      when '美国' then '北美洲'
      when '加拿大' then '北美洲'
    else '其他' end
    ) 洲,
    sum(population) 总数 
    from t_country
    GROUP BY
    (
    case name 
      when '中国' then '亚洲'
      when '日本' then '亚洲'
      when '美国' then '北美洲'
      when '加拿大' then '北美洲'
    else '其他' end
    )

方式一统计结果

image.png

(二)方式二: 使用搜索的case函数进行统计

  select (
    case  
    when name in('中国','日本') then '亚洲'
    when name in('美国','加拿大') then '北美洲'
    else '其他' end
  ) 洲,
  sum(population) 总数 
  from t_country
  GROUP BY
  (
    case  
    when name in('中国','日本') then '亚洲'
    when name in('美国','加拿大') then '北美洲'
    else '其他' end
  )

方式二统计结果

image.png

作用二: 分条件更新字段值

   (一)需求: 将工资低于3000的员工涨幅工资20%,工资等于高于3000的员工涨幅8%,数据如下:

image.png

可能有人看到这个需求的第一反应,想直接可以直接通过如下两条update语句直接更新:

update t_salary set salary = salary + (salary * 0.2) where salary < 3000;
update t_salary set salary = salary + (salary * 0.08) where salary >= 3000;

但是,如果是这样执行的话实际上会存在问题,比如:原来工资在2900的员工,执行完第一条语句后工资会变成3480,此时,再执行第二条更新语句,因为满足工资大于三千,则又会去添加多8%的工资,这样明显就是不符合我们的需求的,所以,如果想完成这个需求,又不想写太复杂的sql,可以通过case函数完成这个功能。

  (二)使用搜索的case函数进行分条件修改(此处不能使用简单case函数,因为简单case函数不能判断带范围的条件)

update t_salary
  set 
  salary = 
  (
    case 
     when salary < 3000 then salary + salary * 0.2
     when salary >= 3000 then salary + salary * 0.08
     else salary 
    end
  )

(三)分条件修改后结果

image.png

作用三: 检查表中字段值是否一致

   (一)需求: 判断两个表中name字段值是否一致,并返回结果,数据如下:

image.png

(二)使用搜索的case函数进行分条件修改(此处不能使用简单case函数,因为简单case函数不能判断带范围的条件)

select name,
(
  case 
  when desciption in(select description from t_user2) then '一致'
  else '不一致'
  end
) 比较结果
from t_user1

(三)比较结果:

image.png

作用四: 行转列(重点-面试常见)

   (一)需求: 将表中数据按照每个学生姓名 、科目、成绩进行排序,数据如下:

image.png

(二)使用case函数转换

// 使用普通case函数
SELECT NAME,
  max( CASE class WHEN '语文' THEN grade ELSE 0 END ) 语文,
  max( CASE class WHEN '数学' THEN grade ELSE 0 END ) 数学,
  max( CASE class WHEN '英语' THEN grade ELSE 0 END ) 英语 
FROM
  t_source 
GROUP BY
NAME
// 使用搜索case函数
SELECT NAME,
  max( CASE  WHEN class = '语文' THEN grade ELSE 0 END ) 语文,
  max( CASE  WHEN class =  '数学' THEN grade ELSE 0 END ) 数学,
  max( CASE  WHEN class = '英语' THEN grade ELSE 0 END ) 英语 
FROM
  t_source 
GROUP BY
NAME

(三)转换结果

image.png

五:普通case函数和搜索case函数的区别

  通过上面的案例可看到,普通的case函数写法相对简洁,但是功能也相对简单,搜索case函数的功能更加强大,具体如下:

  1、简单case函数判断条件只能是等于,而搜索case函数的条件可以是子查询,In,大于、等于等等。

  2、如果只是使用简单的条件分组,可以选择普通case函数,如果需要判断更多的场景,则选择搜索case更好。

六:总结

  如果你想亲自实践,需要本文章的测试数据,可以私信回复: 【测试数据】即可

  看到此处,你应该对Case函数有了更深入的认识,但是、关于Case函数的使用远远不止这一篇文章描述的,还需要我们在实践中去发现更多的可能,如果你看完本文觉得有疑问或者本文有错误的地方,欢迎私信或者在下方留言指出。

  码字不易、如果你觉得本文对你有一点点帮助,可以点赞和关注!


相关文章
|
5月前
|
SQL 分布式计算 DataWorks
DataWorks产品使用合集之如何在SQL语句里使用CASE WHEN语句
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
130 2
|
3月前
|
SQL Oracle 关系型数据库
SQL优化-使用联合索引和函数索引
在一次例行巡检中,发现一条使用 `to_char` 函数将日期转换为字符串的 SQL 语句 CPU 利用率很高。为了优化该语句,首先分析了 where 条件中各列的选择性,并创建了不同类型的索引,包括普通索引、函数索引和虚拟列索引。通过对比不同索引的执行计划,最终确定了使用复合索引(包含函数表达式)能够显著降低查询成本,提高执行效率。
|
3月前
|
SQL 数据库 数据库管理
数据库SQL函数应用技巧与方法
在数据库管理中,SQL函数是处理和分析数据的强大工具
|
3月前
|
SQL 数据库 索引
SQL中COUNT函数结合条件使用的技巧与方法
在SQL查询中,COUNT函数是一个非常常用的聚合函数,用于计算表中满足特定条件的记录数
|
3月前
|
SQL 关系型数据库 MySQL
SQL日期函数
SQL日期函数
|
5月前
|
SQL 数据采集 数据处理
如何在 SQL Server 中使用 LEN 函数
【8月更文挑战第9天】
208 1
如何在 SQL Server 中使用 LEN 函数
|
4月前
|
SQL 关系型数据库 C语言
PostgreSQL SQL扩展 ---- C语言函数(三)
可以用C(或者与C兼容,比如C++)语言编写用户自定义函数(User-defined functions)。这些函数被编译到动态可加载目标文件(也称为共享库)中并被守护进程加载到服务中。“C语言函数”与“内部函数”的区别就在于动态加载这个特性,二者的实际编码约定本质上是相同的(因此,标准的内部函数库为用户自定义C语言函数提供了丰富的示例代码)
|
4月前
|
SQL
SQL: 巧妙使用CASE WHEN实现查询
文章演示了如何利用SQL中的CASE WHEN语句来有效地进行条件性聚合查询,通过具体示例展示了CASE WHEN在统计分析中的应用技巧。
96 0
|
5月前
|
SQL 数据处理 数据库
SQL中的函数有哪些类型
【8月更文挑战第20天】SQL中的函数有哪些类型
58 1
|
5月前
|
SQL 数据处理 数据库