news 2026/4/18 8:38:27

SQL新手必学:CASE WHEN从入门到精通

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQL新手必学:CASE WHEN从入门到精通

快速体验

  1. 打开 InsCode(快马)平台 https://www.inscode.net
  2. 输入框内输入如下内容:
创建一个循序渐进的新手学习教程,包含:1. 基础CASE WHEN语法示例 2. 单条件判断练习 3. 多条件组合案例 4. 嵌套CASE WHEN示范。每个步骤都提供可交互的代码示例和解释说明。要求使用最简单的表结构(如学生成绩表),输出格式要适合初学者理解。使用DeepSeek模型生成教学内容。
  1. 点击'项目生成'按钮,等待项目生成完整后预览效果

SQL新手必学:CASE WHEN从入门到精通

刚开始学SQL的时候,看到CASE WHEN这个语法总觉得有点复杂,但实际用起来才发现它简直是数据处理的神器。今天我就用最通俗的方式,带大家一步步掌握这个超级实用的条件判断语句。

基础语法:理解CASE WHEN的结构

CASE WHEN的语法其实很像我们平时说话的逻辑。比如:"如果成绩大于90分,就是优秀;否则如果大于60分,就是及格;否则就是不及格"。转换成SQL就是:

  1. CASE WHEN 条件1 THEN 结果1
  2. WHEN 条件2 THEN 结果2
  3. ...
  4. ELSE 默认结果
  5. END

举个最简单的例子,我们有个学生成绩表,想给成绩分类:

  • 90分以上为A
  • 80-89为B
  • 70-79为C
  • 60-69为D
  • 60分以下为E

对应的SQL语句就是:

SELECT student_name, score, CASE WHEN score >= 90 THEN 'A' WHEN score >= 80 THEN 'B' WHEN score >= 70 THEN 'C' WHEN score >= 60 THEN 'D' ELSE 'E' END AS grade FROM student_scores;

单条件判断练习

先来练习最简单的单条件判断。假设我们只需要判断学生是否及格:

SELECT student_name, score, CASE WHEN score >= 60 THEN '及格' ELSE '不及格' END AS pass_status FROM student_scores;

这个例子中,我们只用了两个分支: - 当分数≥60时返回"及格" - 其他情况返回"不及格"

多条件组合案例

实际工作中,我们经常需要组合多个条件。比如,除了分数,我们还想考虑出勤率:

SELECT student_name, score, attendance_rate, CASE WHEN score >= 90 AND attendance_rate > 0.9 THEN '优秀学生' WHEN score >= 80 AND attendance_rate > 0.8 THEN '良好学生' WHEN score >= 60 AND attendance_rate > 0.7 THEN '合格学生' ELSE '需要改进' END AS student_level FROM student_scores;

这里我们同时考虑了分数和出勤率两个条件,用AND连接。注意条件的顺序很重要,SQL会从上到下依次判断,一旦满足某个条件就会返回对应的结果。

嵌套CASE WHEN示范

对于更复杂的逻辑,我们可以嵌套使用CASE WHEN。比如先按分数分级,再在每个级别内细分:

SELECT student_name, score, CASE WHEN score >= 90 THEN CASE WHEN score = 100 THEN '满分学霸' ELSE '优秀学生' END WHEN score >= 80 THEN '良好学生' WHEN score >= 60 THEN '合格学生' ELSE '需要努力' END AS student_level FROM student_scores;

这个例子中,我们对90分以上的学生又做了细分:如果是100分,标记为"满分学霸";其他90分以上标记为"优秀学生"。

实际应用技巧

  1. 别忘了END:每个CASE语句都必须以END结束
  2. ELSE是可选的:如果不写ELSE,不符合任何条件时会返回NULL
  3. 条件顺序很重要:SQL会按顺序判断,所以要把最严格的条件放前面
  4. 可以用于任何地方:SELECT、WHERE、ORDER BY等子句都可以用CASE WHEN
  5. 性能考虑:复杂的嵌套CASE WHEN可能会影响查询性能

在InsCode(快马)平台上实践

我最近在InsCode(快马)平台上练习SQL,发现特别适合新手。它的交互式环境让我可以实时看到查询结果,不用自己搭建数据库环境。比如上面的例子,我直接输入SQL就能看到执行效果,还能保存自己的练习记录。

对于想学SQL的朋友,我强烈建议从CASE WHEN开始练习。它不仅能帮你理解条件逻辑,还能处理很多实际业务场景,比如数据分类、条件计算等。记住,多写多练才是掌握SQL的关键!

快速体验

  1. 打开 InsCode(快马)平台 https://www.inscode.net
  2. 输入框内输入如下内容:
创建一个循序渐进的新手学习教程,包含:1. 基础CASE WHEN语法示例 2. 单条件判断练习 3. 多条件组合案例 4. 嵌套CASE WHEN示范。每个步骤都提供可交互的代码示例和解释说明。要求使用最简单的表结构(如学生成绩表),输出格式要适合初学者理解。使用DeepSeek模型生成教学内容。
  1. 点击'项目生成'按钮,等待项目生成完整后预览效果
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 15:20:38

NHSE存档编辑工具:游戏数据管理与效率提升全指南

NHSE存档编辑工具:游戏数据管理与效率提升全指南 【免费下载链接】NHSE Animal Crossing: New Horizons save editor 项目地址: https://gitcode.com/gh_mirrors/nh/NHSE 副标题:如何用专业工具突破《动物森友会》的资源与设计限制? …

作者头像 李华
网站建设 2026/4/7 12:59:40

音乐格式转换与本地解密工具:QMCDecode技术解析与应用指南

音乐格式转换与本地解密工具:QMCDecode技术解析与应用指南 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac,qmc0,qmc3转mp3, mflac,mflac0等转flac),仅支持macOS,可自动识别到QQ音乐下载目录,默…

作者头像 李华
网站建设 2026/4/17 13:03:36

新手友好!YOLOv13镜像自带依赖库一键运行

新手友好!YOLOv13镜像自带依赖库一键运行 你是不是也经历过—— 花一整天配环境,结果卡在 torch 版本不兼容、flash-attn 编译失败、CUDA 和 cuDNN 版本对不上、requirements 安装到一半报错……最后连一张图片都没跑出来? 别折腾了。 这次…

作者头像 李华
网站建设 2026/4/12 3:59:16

极简网盘提速工具:突破限速的高效解决方案

极简网盘提速工具:突破限速的高效解决方案 【免费下载链接】baiduyun 油猴脚本 - 一个免费开源的网盘下载助手 项目地址: https://gitcode.com/gh_mirrors/ba/baiduyun 在数字化时代,网盘已成为我们存储和分享文件的重要工具,但下载速…

作者头像 李华
网站建设 2026/4/16 18:19:55

不安装也能用:在线Maven环境快速验证创意

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 构建一个基于浏览器的Maven项目快速原型环境,集成在线的Maven工具链,用户可以直接在网页中创建、编辑和构建Maven项目。支持POM文件编辑、依赖管理、项目构…

作者头像 李华
网站建设 2026/4/7 15:39:45

AI如何帮你自动优化Docker Engine配置?

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个AI辅助Docker配置优化工具,能够根据用户输入的应用程序类型(如Web服务、数据库等)、预期负载和资源限制,自动生成优化的Doc…

作者头像 李华