当前位置:网站首页>零基础自学SQL课程 | IF函数
零基础自学SQL课程 | IF函数
2022-06-27 21:13:00 【喵宁一】
大家好,我是宁一。
今天是我们的第22课:IF函数。
大家如果学过其他编程语言,应该对IF函数很熟悉了。用来根据条件,返回不同值。
基本语法:
IF(条件表达式, 值1, 值2)如果条件表达式为True,返回值1,为False,返回值2。
返回值可以是任何值,比如:数值、文本、日期、空值NULL、数学表达式、函数等。
1、 IF函数
实例:在Students表中,将1995年及之前出生的学生划分为1班,1995年以后出生的学生划分为2班,最后显示Sname,Sage,所在班级这3列。

示例结果:

SELECT
Sname,
Sage,
IF(
YEAR(Sage) <=1995, "1班","2班"
) AS "所在班级"
FROM Students;2、IF函数嵌套
当分类大于两种时,可以将IF函数嵌套实现。
实例:在Students表中,学生编号Sid小于等于3的学生,属于1班;Sid为4到6的学生,属于2班;Sid大于等于7的学生属于3班。最后显示Sname,Sage,所在班级这3列。
SELECT
Sid,
Sname,
IF(Sid<=3,"1班",
IF(Sid>=7,'3班','2班')
) AS "所在班级"
FROM Students
嵌套函数看起来还是有点麻烦的,如果分类大于两种,可以用CASE关键词代替IF函数嵌套,下节课我们会具体讲解。
3、IF+聚合函数
IF函数还经常与聚合函数结合使用,我们来看看实例。
实例:集合Teacher表和Students,计算班主任所带学生的人数,大于等于5的显示“5人及以上”,人数小于5的显示“5人以下”。

示例结果:

SELECT
t.Tname,
COUNT(*) AS "学生人数",
IF(COUNT(*)>=5,"5人及以上","5人以下") AS "分类"
FROM Teachers t
JOIN Students s
ON t.Tid = s.Tid
GROUP BY t.Tname;下节课我们讲讲 CASE 函数。
点击关注,更新课程第一时间通知哦~
边栏推荐
- mysql读写分离配置
- 通过 MQTT 检测对象和传输图像
- 解决新版chrome跨域问题:cookie丢失以及samesite属性问题「建议收藏」
- 电子科大(申恒涛团队)&京东AI(梅涛团队)提出用于视频问答的结构化双流注意网络,性能SOTA!优于基于双视频表示的方法!
- 发射,接收天线方向图
- [learn FPGA programming from scratch -48]: Vision - development and application of intelligent sensors
- Vivado FFT IP的使用说明
- Discuz small fish game wind shadow legend business gbk+utf8 version template /dz game website template
- The file or assembly 'cefsharp.core.runtime.dll' or one of its dependencies could not be loaded. Is not a valid Win32 Application. (exception from hresult:0x800700c1)
- Swing UI——容器(一)
猜你喜欢

未能加载文件或程序集“CefSharp.Core.Runtime.dll”或它的某一个依赖项。 不是有效的 Win32 应用程序。 (异常来自 HRESULT:0x800700C1)

消除el-image图片周围间隙

Working at home is more tiring than going to work at the company?

小芯片chiplet技术杂谈

UESTC (shenhengtao team) & JD AI (Mei Tao team) proposed a structured dual stream attention network for video Q & A, with performance SOTA! Better than the method based on dual video representation!

webserver流程图——搞懂webserver各模块间调用关系

fiddler 监听不到接口怎么办

How vivado adds timing constraints

【tinyriscv verilator】分支移植到正点原子达芬奇开发板

Prediction of benign / malignant breast tumors (logistic regression classifier)
随机推荐
First principles (optimal solution theory)
Applet referer
【AI应用】NVIDIA GeForce RTX 3060的详情参数
c语言-日期格式化[通俗易懂]
云辅助隐私集合求交(Server-Aided PSI)协议介绍:学习
[js]var, let, const
Vivado FFT IP的使用说明
如何设置企业微信群机器人定时发消息?
量化交易入门教程
【PCL自学:PCLVisualizer】点云可视化工具PCLVisualizer
新加坡国立大学|采用无模型强化学习方法评估能源效益数据中心的节能情况
Swing UI——容器(一)
Storage structure of graph
ICML 2022: UFRGS |作为最优策略转移基础的乐观线性支持和后继特征
【tinyriscv verilator】分支移植到正点原子达芬奇开发板
良/恶性乳腺肿瘤预测(逻辑回归分类器)
虽然TCGA数据库有33种癌症
【PCL自学:Segmentation4】基于Min-Cut点云分割
Stream + Nacos
golang使用mongo-driver操作——查(基础)