sql语句case when常用查询总结

一、case when 语句语法逻辑

case when 是mySQL里面的控制流语句,和if…then…的分支判断逻辑很相似。

case when语句有两种:
(1)简单case when
(2)case搜索函数法
简单case when只能处理等式问题,case搜索函数法可以处理等式问题也可以处理不等式问题。

case when的语法逻辑

#
case 
  when Condition1 then result1
  when Condition2 then result2
  ......
  else result
end 
#或者end as name1
#end非常容易丢,一定要注意

二、case when语句在业务中常见的几种用法

2.1 数据映射处理

比如将分类变量中每一个取值分别映射成0、1、2…5;所有用户的性别映射成0、1;或者把数值映射成具体的实际含义。
如果是映射性别(0为女,1为男)

select *,
  case
      when is_male = 0 then '女'
      else '男'
  end as is_male_new
from table1

2.2. 连续数据离散化处理(分箱操作)

有时需要对数据进行分箱操作,也就是连续数据离散化处理。比如将所有用户按照收入分为高、中、低收入人群;按年龄可以将总体分为老年、中年、青年全体;按用户访问次数将群体分为高活跃状态用户、中等活跃状态用户、低活跃状态用户。分箱操作之后,就可以进行用户群分析等研究操作。
代码如下:

select *,
  case
      when year
  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
SQL语句中的CASE WHEN是一种条件表达式函数,用于根据给定的条件返回不同的结果值。它的语法可以有多种形式。其中一种形式是使用CASE WHEN语句来进行多条件判断。例如,可以使用CASE WHEN来根据学生的分数判断其等级,如下所示: CASE WHEN SCORE = 'A' THEN '优' WHEN SCORE = 'B' THEN '良' WHEN SCORE = 'C' THEN '中' ELSE '不及格' END 上述代码中,如果分数等于'A',则返回'优',如果分数等于'B'则返回'良',如果分数等于'C'则返回'中',否则返回'不及格'。注意,所有返回值的类型应该一致,否则会报错。 另一种形式是使用简化的CASE WHEN语句,如下所示: CASE SCORE WHEN 'A' THEN '优' ELSE '不及格' END 这种形式的CASE WHEN语句与上述代码的效果是相同的,根据分数判断返回不同的结果值。同样,返回值的类型应一致。 除了上述例子中直接判断分数的情况,还可以在SELECT语句中使用CASE WHEN来进行条件判断,并在结果集中返回对应的备注。例如: SELECT STUDENT_NAME, (CASE WHEN score < 60 THEN '不及格' WHEN score >= 60 AND score < 80 THEN '及格' WHEN score >= 80 THEN '优秀' ELSE '异常' END) AS REMARK FROM TABLE 上述代码中,根据不同的分数范围,返回相应的备注值。如果分数小于60,则返回'不及格',如果分数大于等于60且小于80,则返回'及格',如果分数大于等于80,则返回'优秀',否则返回'异常'。 需要注意的是,如果想要判断分数是否为null的情况,不能使用WHEN score = null的写法,而应该使用IS NULL来判断。例如,当score为null时,可以使用WHEN score IS NULL THEN '缺席考试'来判断。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [sql case when的用法(转)](https://blog.csdn.net/weixin_43955984/article/details/101000234)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值