SQL:MySQL函数:条件函数(Conditional Functions)

目录

什么是条件函数?

[常用 MySQL 条件函数总览表](#常用 MySQL 条件函数总览表)

[1️⃣ IF() -- 条件判断函数(If Statement)](#1️⃣ IF() – 条件判断函数(If Statement))

[2️⃣ IFNULL() -- 空值判断与替代函数(If Null)](#2️⃣ IFNULL() – 空值判断与替代函数(If Null))

[3️⃣ NULLIF() -- 相等返回 NULL(Null If Equal)](#3️⃣ NULLIF() – 相等返回 NULL(Null If Equal))

[4️⃣ CASE -- 多条件判断结构(Case When)](#4️⃣ CASE – 多条件判断结构(Case When))

常见使用场景


什么是条件函数?

条件函数是指在 SQL 查询过程中,根据某个条件的真假来决定返回哪一个值的函数。它们常用于控制逻辑流程、数据筛选、分类处理等场景。

常用 MySQL 条件函数总览表

函数名称(英文) 中文含义 语法格式 含义解释 示例
IF() 条件判断函数 IF(condition, true_value, false_value) 如果条件为真,返回 true_value,否则返回 false_value IF(score>=60, '及格', '不及格')
IFNULL() 空值替换函数 IFNULL(expr1, expr2) 如果 expr1 不为 NULL,返回 expr1,否则返回 expr2 IFNULL(bonus, 0)
NULLIF() 相等转 NULL 函数 NULLIF(expr1, expr2) 如果 expr1expr2 相等,返回 NULL,否则返回 expr1 NULLIF(grade, 'F')
CASE 多条件分支判断 CASE WHEN condition THEN result ... ELSE result END 按照多个条件分支进行判断 CASE WHEN salary>10000 THEN '高薪' WHEN salary>5000 THEN '中等' ELSE '低薪' END

1️⃣ IF() -- 条件判断函数(If Statement)

  • 英文含义:IF → if statement

  • 中文解释:根据一个条件是否为真来返回不同的结果(类似于 if-else)。

  • 语法:

sql 复制代码
IF(condition, value_if_true, value_if_false)

示例:

sql 复制代码
SELECT name, IF(score >= 60, '合格', '不合格') AS result FROM students;

2️⃣ IFNULL() -- 空值判断与替代函数(If Null)

  • 英文含义:IFNULL → if null

  • 中文解释:判断某个值是否为 NULL,如果是,则返回指定默认值。

  • 语法:

sql 复制代码
IFNULL(expression, replacement_value)

示例:

sql 复制代码
SELECT name, IFNULL(score, 0) AS final_score FROM students;

3️⃣ NULLIF() -- 相等返回 NULL(Null If Equal)

  • 英文含义:NULLIF → null if equal

  • 中文解释:如果两个表达式相等,则返回 NULL,否则返回第一个表达式。常用于防止除以 0 的错误。

  • 语法:

sql 复制代码
NULLIF(expr1, expr2)

示例:

sql 复制代码
SELECT score / NULLIF(attempts, 0) FROM exam_results;

4️⃣ CASE -- 多条件判断结构(Case When)

  • 英文含义:CASE → conditional switch

  • 中文解释:类似于其他语言中的 switch-case,实现多条件判断与分类。

  • 语法:

sql 复制代码
CASE 
  WHEN condition1 THEN result1
  WHEN condition2 THEN result2
  ...
  ELSE resultN
END

示例:

sql 复制代码
SELECT 
  name,
  CASE 
    WHEN score >= 90 THEN '优秀'
    WHEN score >= 60 THEN '及格'
    ELSE '不及格'
  END AS level
FROM students;

常见使用场景

场景 使用函数 示例语句
判断通过与否 IF() IF(score >= 60, '通过', '未通过')
缺失值替代 IFNULL() IFNULL(phone, '无号码')
防止除以 0 NULLIF() sales / NULLIF(quantity, 0)
多等级分类 CASE CASE WHEN age < 18 THEN '未成年' ELSE '成年' END
相关推荐
m0_613856292 小时前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
Adios7942 小时前
VPR:Pitts50K和Norland数据集下载
数据库
东风破1373 小时前
DM用户权限、表、约束等对象的基本操作,SQL日志的开启介绍
数据库·sql·dm达梦数据库
收获不止数据库3 小时前
达梦9发布会归来:AI 时代,我们需要一款什么样的数据库?
数据库·人工智能·ai·语言模型·数据分析
小宇的天下3 小时前
Virtuoso GUI 界面中的关键模块定义
数据库
bqq198610263 小时前
MySQL 5.7 与 MySQL 8.0 的主要区别
数据库·mysql
juniperhan3 小时前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
Elastic 中国社区官方博客4 小时前
Elastic-caveman : 在不损失 Elastic 最佳效果的情况下,将 AI 响应 tokens 减少64%
大数据·运维·数据库·人工智能·elasticsearch·搜索引擎·全文检索
互联网推荐官4 小时前
上海软件定制开发全流程拆解:需求分析、技术选型与交付管理的工程实践
大数据·数据库·需求分析
专注API从业者4 小时前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库