[MySQL学习笔记]case when then else end用法

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SunnyYoona/article/details/51549260 Case具有两种格式。
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SunnyYoona/article/details/51549260

Case具有两种格式。简单Case函数和Case搜索函数。

(1)简单Case函数

 
 
  1. CASE sex
  2.         WHEN '1' THEN '男'
  3.         WHEN '2' THEN '女'
  4. ELSE '其他' END

(2)Case搜索函数

 
 
  1. CASE WHEN sex = '1' THEN '男'
  2.         WHEN sex = '2' THEN '女'
  3. ELSE '其他' END

这两种方式,可以实现相同的功能。简单Case函数的写法相对比较简洁,但是和Case搜索函数相比,功能方面会有些限制,比如写判断式。还有一个需要注意的问题,Case函数只返回第一个符合条件的值,剩下的Case部分将会被自动忽略。

 
 
  1. --比如说,下面这段SQL,你永远无法得到“第二类”这个结果
  2. CASE WHEN col_1 IN ( 'a', 'b') THEN '第一类'
  3.         WHEN col_1 IN ('a')       THEN '第二类'
  4. ELSE'其他' END


(3)如下场景,给出了一些国家以及对应的人口数据。我们根据这些国家的人口数据,统计亚洲和北美洲的人口数量。

国家 人口
中国 600
美国 100
加拿大 100
英国 200
法国 300
日本 250
德国 200
墨西哥 50
印度 250

创建国家表(country),包含两个字段country和population:

 
 
  1. CREATE TABLE country (  country VARCHAR(40) NOT NULL DEFAULT '' COMMENT '国家',  population double NOT NULL DEFAULT 0.0 COMMENT '人口') ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='国家表';

插入数据:

 
 
  1. insert into country values('中国',600),('美国',100),('加拿大',100),('英国',200),('法国',300),('日本',250),('德国',200),('墨西哥',50),('印度',250)

统计亚洲和北美洲的人口数量:

 
 
  1. SELECT  SUM(population) as sum,
  2.        (CASE country
  3.                WHEN '中国'     THEN '亚洲'
  4.                WHEN '印度'     THEN '亚洲'
  5.                WHEN '日本'     THEN '亚洲'
  6.                WHEN '美国'     THEN '北美洲'
  7.                WHEN '加拿大'  THEN '北美洲'
  8.                WHEN '墨西哥'  THEN '北美洲'
  9.        ELSE '其他' END) continents
  10. FROM    country
  11. GROUP BY CASE country
  12.                WHEN '中国'     THEN '亚洲'
  13.                WHEN '印度'     THEN '亚洲'
  14.                WHEN '日本'     THEN '亚洲'
  15.                WHEN '美国'     THEN '北美洲'
  16.                WHEN '加拿大'  THEN '北美洲'
  17.                WHEN '墨西哥'  THEN '北美洲'
  18.        ELSE '其他' END;

统计结果:

sun continents
1100 亚洲
700 其他
250 北美洲

(4)如下场景,给出了一些国家以及对应性别的人口数据。我们根据这些国家的人口数据,分别统计男性和女性的人口数量。

国家 性别 人口
中国 1 340
中国 2 260
美国 1 45
美国 2 55
加拿大 1 51
加拿大 2 49
英国 1 40
英国 2 60

创建国家表(country2),包含三个字段country,sex和population:

 
 
  1. CREATE TABLE country2 (  country VARCHAR(40) NOT NULL DEFAULT '' COMMENT '国家',  sex tinyint NOT NULL DEFAULT 1 COMMENT '性别',  population double NOT NULL DEFAULT 0.0 COMMENT '人口') ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='国家表';

插入数据:

 
 
  1. insert into table country values('中国',1,340),('中国',2,260),('美国',1,45),('美国',2,55),('加拿大',1,51),('加拿大',2,49),('英国',1,40),('英国',2,60)
按照国家和性别进行分组,统计人口数量:
 
 
  1. SELECT country,
  2.       SUM( CASE WHEN sex = '1' THEN
  3.                      population ELSE 0 END) as boy,
  4.       SUM( CASE WHEN sex = '2' THEN
  5.                      population ELSE 0 END) as girl
  6. FROM  country2
  7. GROUP BY country;

统计结果:

国家 boy girl
中国 340 260
加拿大 51 49
美国 45 55
英国 40 60



来源于:点击打开链接


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
132 6
|
2月前
|
关系型数据库 MySQL 索引
mysql中EXISTS用法注意点
mysql中EXISTS用法注意点
|
1月前
|
SQL 关系型数据库 MySQL
Mysql学习笔记(三):fetchone(), fetchmany(), fetchall()详细总结
MySQL中用于数据检索的`fetchone()`, `fetchmany()`, `fetchall()`函数的功能、SQL语句示例和应用场景。
59 3
Mysql学习笔记(三):fetchone(), fetchmany(), fetchall()详细总结
|
1月前
|
SQL Ubuntu 关系型数据库
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
本文为MySQL学习笔记,介绍了数据库的基本概念,包括行、列、主键等,并解释了C/S和B/S架构以及SQL语言的分类。接着,指导如何在Windows和Ubuntu系统上安装MySQL,并提供了启动、停止和重启服务的命令。文章还涵盖了Navicat的使用,包括安装、登录和新建表格等步骤。最后,介绍了MySQL中的数据类型和字段约束,如主键、外键、非空和唯一等。
71 3
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
|
24天前
|
存储 SQL NoSQL
|
1月前
|
关系型数据库 MySQL 数据库
Mysql学习笔记(四):Python与Mysql交互--实现增删改查
如何使用Python与MySQL数据库进行交互,实现增删改查等基本操作的教程。
67 1
|
1月前
|
存储 SQL 关系型数据库
mysql用法
mysql用法
41 4
|
2月前
|
存储 自然语言处理 关系型数据库
MySQL的match用法说明
MySQL的match用法说明
126 4
|
2月前
|
SQL 关系型数据库 MySQL
MySQL的用法
MySQL的用法
55 1
|
15天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
29 1

热门文章

最新文章

下一篇
无影云桌面