有学有练才叫学习:学而不思则罔,思而不学则殆:学而不习,纸上谈兵,习而不进,画地为牢!

sql if函数(一文讲懂SQL条件语句 IF函数)

MySQL 炮渣日记 2周前 (11-18) 17次浏览 已收录 0个评论 扫描二维码

基本语法:

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

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

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

1、 IF函数

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

sql if函数(一文讲懂SQL条件语句 IF函数)

示例结果:

sql if函数(一文讲懂SQL条件语句 IF函数)
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
sql if函数(一文讲懂SQL条件语句 IF函数)

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

3、IF+聚合函数

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

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

sql if函数(一文讲懂SQL条件语句 IF函数)

示例结果:

sql if函数(一文讲懂SQL条件语句 IF函数)
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;
喜欢 (0)
炮渣日记
关于作者:
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址