[数据库] 一文搞懂case when所有使用场景「建议收藏」

[数据库] 一文搞懂case when所有使用场景「建议收藏」前几天,为了给产品分析当前用户数据结构,写sql的时候使用到了casewhen,今天来总结一下casewhen的使用方法,以此为戒,感觉写的不好请拍砖,感觉写的还可以,给哥们点个赞,或者回复一下,让我意识到我不是一个人在战斗,好了废话不多说了,进入正题。关于casewhen的使用情况,我总结下来有三种,第一、等值转换,第二、范围转换,第三、列转行操作。等值转换咱们在设计数据库的…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

前几天,为了给产品分析当前用户数据结构,写sql的时候使用到了case when,今天来总结一下case when 的使用方法,以此为戒,感觉写的不好请拍砖,感觉写的还可以,给哥们点个赞,或者回复一下,让我意识到我不是一个人在战斗,好了废话不多说了,进入正题。

关于case when的使用情况,我总结下来有三种,第一、等值转换,第二、范围转换,第三、列转行操作。

等值转换

咱们在设计数据库的时候总是会把用户的性别用int存储(’0’为女,’1’为男),但是怎么把它转换成汉字显示呢?

原始表数据

[数据库] 一文搞懂case when所有使用场景「建议收藏」

SQL语句

select
name as ‘名字’,
(case sex when 0 then ‘女’ else ‘男’ end) as ‘性别’
from test.student;

ps.最后的 ‘end’ 别丢了,我刚开始使用的时候我就有这个毛病,并且一般的case when语句都会比较长,最好添加小括号包起来,这样更容易阅读。

查询结果

[数据库] 一文搞懂case when所有使用场景「建议收藏」

范围转换

有的时候,也会遇到这种情况,按照用户成绩显示优(90+)、良(80-90)、及格(60-80)、未及格(60-),这个跟第一个不同的是,他是一个分数的范围,要怎么转换成汉子显示呢?你可能觉得很简单,不就是吧when那换成条件吗?先打住咱们往下看

原始表数据

[数据库] 一文搞懂case when所有使用场景「建议收藏」

 

SQL语句

select 
name as ‘姓名’
,(case score when score>=90 then ‘优’ when score>=80 then ‘良’ when score>=60 then ‘及格’ else ‘不及格’ end) as ‘等级’
from test.stu_score; 

这样写对不?

这个查出来的结果是

[数据库] 一文搞懂case when所有使用场景「建议收藏」

 

[数据库] 一文搞懂case when所有使用场景「建议收藏」

这是为啥呢?想明白了吗? 

因为 case when就像一个 switch case语句一样,如果你在case后填了东西,它会拿后它跟when 对比,咱们的 写的case 后写=了 score 而when后面写了score>=90 ,然而,’score’ 等于 ‘score>=90’吗? 显然不等于,那该怎么写呢?

select 
name as ‘姓名’
,(case score when score>=90 then ‘优’ when score>=80 then ‘良’ when score>=60 then ‘及格’ else ‘不及格’ end) as ‘等级’
from test.stu_score; 

[数据库] 一文搞懂case when所有使用场景「建议收藏」

 

列转行操作

还是用学生的例子吧,现在有图1学生成绩数据, 现在要怎么按图2显示出来呢?

图1

[数据库] 一文搞懂case when所有使用场景「建议收藏」

图2

[数据库] 一文搞懂case when所有使用场景「建议收藏」

 

第一步 先按照科目分开, 符合条件的设置分数,不符合的给置零。

select name as ‘姓名’
,(case course when ‘语文’ then score else 0 end) as ‘语文’
,(case course when ‘数学’ then score else 0 end) as ‘数学’
,(case course when ‘英语’ then score else 0 end) as ‘英语’
from test.course_score

[数据库] 一文搞懂case when所有使用场景「建议收藏」

 

然后再按照名字group by ,对分数求max。

select name as ‘姓名’
,max(case course when ‘语文’ then score else 0 end) as ‘语文’
,max(case course when ‘数学’ then score else 0 end) as ‘数学’
,max(case course when ‘英语’ then score else 0 end) as ‘英语’
from test.course_score group by name;

[数据库] 一文搞懂case when所有使用场景「建议收藏」

 

后天就是除夕了,在这里给各位CSDN的朋友拜个早年,祝各位在新一年里,工资翻倍,不掉头发!

老铁们,别光收藏啊,点个赞再走啊!

❤️ 看完三件事

如果你觉得这篇内容对你挺有启发,我想邀请你帮我三个小忙:

  1. 点赞,让更多的人也能看到这篇内容(收藏不点赞,都是耍流氓 -_-)
  2. 微信搜索jinhuazhe2010加我,进组织,不定期分享干货。
  3. 也看看其它文章
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196898.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • vim 使用指南

    vim 使用指南

    2021年4月23日
    214
  • prepareStatement使用「建议收藏」

    prepareStatement使用「建议收藏」publicbooleanlogin2(Stringusername,Stringpassword)throwsException{ Stringurl=”jdbc:mysql://localhost:3306/mydb1″; Class.forName(“com.mysql.jdbc.Driver”); StringsqlUsername=”root”;

    2022年6月2日
    44
  • url—pattern_pattern

    url—pattern_pattern首先说下,其实url-pattern就是说的url模式,就是容器在查找时根据这个模式来找到具体的servlet来执行。先来看一段规范中的IntheWebapplicationdeploymentdescriptor,thefollowingsyntaxisusedtodefinemappings:Astringbeginningwith

    2022年10月25日
    0
  • 平衡二叉树的数据结构_红黑树数据结构

    平衡二叉树的数据结构_红黑树数据结构红黑树Java集合系列之TreeMap详细介绍(源码解析)和使用示例代码来自算法第四版红黑树并不追求“完全平衡”——它只要求部分地达到平衡要求,降低了对旋转的要求,从而提高了性能。红黑树实际上是由2-3-4树转换而来,红黑树能够以O(log2n)的时间复杂度进行搜索、插入、删除操作。此外,由于它的设计,任何不平衡都会在三次旋转之内解决。当然,还有一些更好的,但实现起来更复杂的数据

    2022年8月30日
    0
  • 计算机最炫民族风教案,辽师大版信息技术四下第一单元第6课《最炫民族风》教案7.docx…[通俗易懂]

    计算机最炫民族风教案,辽师大版信息技术四下第一单元第6课《最炫民族风》教案7.docx…[通俗易懂]辽师大版信息技术四下第一单元第6课《最炫民族风》教案7.docx文档编号:536850文档页数:5上传时间:2019-01-13文档级别:文档类型:docx文档大小:7.00MB课课题题美丽的辽宁我的家美丽的辽宁我的家–WordWord软件的简单应用软件的简单应用66、、最炫民族风最炫民族风教学目标教学目标1、学会结合文章的内容进行分栏;2、学会设置页面颜色与页面效果;3、…

    2022年9月22日
    0
  • php隐式转换,隐式转换如何使用?总结隐式转换实例用法「建议收藏」

    php隐式转换,隐式转换如何使用?总结隐式转换实例用法「建议收藏」JavaScript的数据类型分为六种,分别为null,undefined,boolean,string,number,object。object是引用类型,其它的五种是基本类型或者是原始类型。我们可以用typeof方法打印来某个是属于哪个类型的。不同类型的变量比较要先转类型,叫做类型转换,类型转换也叫隐式转换。隐式转换通常发生在运算符加减乘除,等于,还有小于,大于等。。typeof’11’…

    2022年10月11日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号