大数据学习(107)-sql中case使用场景

🍋🍋大数据学习🍋🍋

🔥系列专栏: 👑哲学语录: 用力所能及,改变世界。
💖如果觉得博主的文章还不错的话,请点赞👍+收藏⭐️+留言📝支持一下博主哦🤞


在 SQL 中,CASE 语句是处理条件逻辑的核心工具,以下是 6 个典型使用场景及示例:

1. 数据分类统计

将连续数值分段统计(如年龄、分数):

sql 复制代码
SELECT 
CASE 
WHEN age < 18 THEN '未成年'
WHEN age BETWEEN 18 AND 65 THEN '成年'
ELSE '老年'
END AS age_group,
COUNT(*) AS count
FROM users
GROUP BY age_group;
2. 条件聚合计算

根据条件计算不同聚合值(如动态求和):

sql 复制代码
SELECT 
product_id,
SUM(CASE WHEN order_date > '2025-01-01' THEN price ELSE 0 END) AS sales_2025,
SUM(CASE WHEN order_date <= '2025-01-01' THEN price ELSE 0 END) AS sales_before_2025
FROM orders
GROUP BY product_id;
3. 数据格式转换

将编码值转为可读文本(如状态码转文字):

sql 复制代码
SELECT 
order_id,
CASE status
WHEN 1 THEN '待付款'
WHEN 2 THEN '已发货'
WHEN 3 THEN '已完成'
ELSE '未知状态'
END AS status_text
FROM orders;
4. 处理 NULL 值

在聚合函数中优雅处理空值:

sql 复制代码
SELECT 
AVG(CASE WHEN salary IS NULL THEN 0 ELSE salary END) AS avg_salary
FROM employees;
5. 动态排序规则

根据不同条件动态调整排序逻辑:

sql 复制代码
SELECT *
FROM products
ORDER BY 
CASE 
WHEN category = '电子' THEN price * 0.9 -- 电子产品打9折后排序
ELSE price
END DESC;
6. 复杂逻辑嵌套

结合其他函数实现多层判断(如评分评级):

sql 复制代码
SELECT 
user_id,
CASE 
WHEN score >= 90 THEN 'A'
WHEN score >= 80 THEN 'B'
WHEN score >= 70 THEN 'C'
ELSE 'D'
END AS rating
FROM evaluations;

核心优势

  • 灵活性:支持多条件分支和复杂逻辑组合
  • 可读性:将业务规则直接映射为 SQL 代码
  • 兼容性 :所有主流数据库均支持 CASE 语法
  • 性能:通常比应用程序层处理更高效

通过合理使用 CASE,可以实现 SQL 查询的逻辑复用动态计算,是数据分析中不可或缺的工具。

相关推荐
字节跳动数据平台1 小时前
代码量减少 70%、GPU 利用率达 95%:火山引擎多模态数据湖如何释放模思智能的算法生产力
大数据
得物技术2 小时前
深入剖析Spark UI界面:参数与界面详解|得物技术
大数据·后端·spark
武子康4 小时前
大数据-238 离线数仓 - 广告业务 Hive分析实战:ADS 点击率、购买率与 Top100 排名避坑
大数据·后端·apache hive
武子康1 天前
大数据-237 离线数仓 - Hive 广告业务实战:ODS→DWD 事件解析、广告明细与转化分析落地
大数据·后端·apache hive
大大大大晴天1 天前
Flink生产问题排障-Kryo serializer scala extensions are not available
大数据·flink
武子康3 天前
大数据-236 离线数仓 - 会员指标验证、DataX 导出与广告业务 ODS/DWD/ADS 全流程
大数据·后端·apache hive
武子康4 天前
大数据-235 离线数仓 - 实战:Flume+HDFS+Hive 搭建 ODS/DWD/DWS/ADS 会员分析链路
大数据·后端·apache hive
DianSan_ERP5 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
够快云库5 天前
能源行业非结构化数据治理实战:从数据沼泽到智能资产
大数据·人工智能·机器学习·企业文件安全
西岸行者5 天前
学习笔记:SKILLS 能帮助更好的vibe coding
笔记·学习