• 零基础自学SQL课程 | IF函数


    大家好,我是宁一。

    今天是我们的第22课:IF函数。

    大家如果学过其他编程语言,应该对IF函数很熟悉了。用来根据条件,返回不同值。

    基本语法:

    IF(条件表达式, 值1, 值2)

    如果条件表达式为True,返回值1,为False,返回值2。

    返回值可以是任何值,比如:数值、文本、日期、空值NULL、数学表达式、函数等。

    1、 IF函数

    实例:在Students表中,将1995年及之前出生的学生划分为1班,1995年以后出生的学生划分为2班,最后显示Sname,Sage,所在班级这3列。

    示例结果:

    1. SELECT
    2. Sname,
    3. Sage,
    4. IF(
    5. YEAR(Sage) <=1995, "1班","2班"
    6. ) AS "所在班级"
    7. FROM Students;

    2、IF函数嵌套

    当分类大于两种时,可以将IF函数嵌套实现。

    实例:在Students表中,学生编号Sid小于等于3的学生,属于1班;Sid为4到6的学生,属于2班;Sid大于等于7的学生属于3班。最后显示Sname,Sage,所在班级这3列。

    1. SELECT
    2. Sid,
    3. Sname,
    4. IF(Sid<=3,"1班",
    5. IF(Sid>=7,'3班','2班')
    6. ) AS "所在班级"
    7. FROM Students

    嵌套函数看起来还是有点麻烦的,如果分类大于两种,可以用CASE关键词代替IF函数嵌套,下节课我们会具体讲解。

    3、IF+聚合函数

    IF函数还经常与聚合函数结合使用,我们来看看实例。

    实例:集合Teacher表和Students,计算班主任所带学生的人数,大于等于5的显示“5人及以上”,人数小于5的显示“5人以下”。

    示例结果:

    1. SELECT
    2. t.Tname,
    3. COUNT(*) AS "学生人数",
    4. IF(COUNT(*)>=5,"5人及以上","5人以下") AS "分类"
    5. FROM Teachers t
    6. JOIN Students s
    7. ON t.Tid = s.Tid
    8. GROUP BY t.Tname;

    下节课我们讲讲 CASE 函数。

    点击关注,更新课程第一时间通知哦~

  • 相关阅读:
    USB PD快充协议
    MySQL常用操作
    (十五)VBA常用基础知识:正则表达式的使用
    java File类创建功能
    Vue3中defineEmits、defineProps 是怎么做到不用引入就能直接用的
    狮子鱼社区团购小程序V18.9全开源独立版+小程序前端 安装教程
    全局异常处理器无法处理sql报错
    JUnit单元测试
    在宇宙的眼眸下,如何正确地关心东数西算?
    【gitlab】我的gitlab经历--20220901
  • 原文地址:https://blog.csdn.net/shine_a/article/details/125473236