技术文摘
SQL 中 CASE 函数使用方法
2025-01-14 19:41:16 小编
SQL 中 CASE 函数使用方法
在 SQL 编程领域,CASE 函数是一个极为实用的工具,它允许我们在查询中进行条件判断和分支处理,为数据检索和处理带来了极大的灵活性。
CASE 函数主要有两种形式:简单 CASE 函数和搜索 CASE 函数。
简单 CASE 函数语法为:
CASE expression
WHEN value1 THEN result1
WHEN value2 THEN result2
...
ELSE result
END
在这里,expression 是要被计算的表达式。SQL 会依次将 expression 的值与 WHEN 子句中的 value 进行比较。如果匹配到某个 value,就返回对应的 result。如果没有匹配到任何 WHEN 子句的值,就返回 ELSE 子句中的 result。例如,我们有一个存储学生成绩的表 students,包含列 student_id、name 和 score。要根据成绩划分等级,可以这样写查询:
SELECT
student_id,
name,
CASE
WHEN score >= 90 THEN 'A'
WHEN score >= 80 THEN 'B'
WHEN score >= 70 THEN 'C'
ELSE 'D'
END AS grade
FROM
students;
搜索 CASE 函数语法为:
CASE
WHEN condition1 THEN result1
WHEN condition2 THEN result2
...
ELSE result
END
这种形式下,WHEN 后面跟着的是条件表达式 condition。SQL 会依次评估这些条件,当某个条件为真时,返回对应的 result。若所有条件都为假,则返回 ELSE 子句的 result。比如,要在一个员工表 employees 中,根据不同的工资范围计算奖金:
SELECT
employee_id,
name,
salary,
CASE
WHEN salary < 5000 THEN salary * 0.1
WHEN salary < 8000 THEN salary * 0.15
ELSE salary * 0.2
END AS bonus
FROM
employees;
CASE 函数不仅可以用于 SELECT 语句,还能在 UPDATE、DELETE 等语句中发挥作用,实现根据不同条件对数据进行更新或删除操作。掌握 CASE 函数的使用方法,能够让我们在处理复杂业务逻辑时更加得心应手,提升 SQL 查询的效率和实用性,为数据库管理和数据分析工作带来便利。
- 提取 Dockerfile 从 Docker 镜像的两种方式
- Docker 部署可执行 Jar 包的思路及完整流程
- Docker 安装 Jenkins 用于微服务多模块打包的示例代码
- K8s 中查看 Pod 日志的实用方法汇总
- Docker 进阶:自定义镜像构建实战指引
- docker 镜像管理命令全解析
- VMware 中 Ubuntu 共享文件夹问题的解决之道
- Docker 私有仓库搭建配置的实现步骤
- Docker Buildx 多平台镜像构建的实现
- Docker 中 Redis 集群(主从 + 哨兵)安装配置的实现流程
- Docker 配置 redis sentinel 哨兵的方法与步骤
- 基于 Docker 搭建 Redis 哨兵集群并与 Spring Boot 整合的实现
- Docker 镜像基本操作方法详解
- 阿里云服务器上 Docker Swarm 集群的部署
- Docker 实现 Redis 主从哨兵集群的搭建步骤