MySQL使用CASE WHEN统计SQL语句代替子查询SQL统计,CASE WHEN常用写法,根据不同的条件对数据进行分类、分组和聚合

news2024/12/25 22:10:03

MySQL中,写一个CASE WHEN的统计SQL语句,代替子查询SQL统计语句

假设我们有一个名为"orders"的表,其中包含订单信息,包括订单号(order_id)、订单金额(order_amount)等列。我们想要统计每个订单级别的订单数量,之前使用子查询的方式可能是这样的:

SELECT  
    COUNT(*) AS order_count,  
    (SELECT COUNT(*) FROM orders WHERE order_amount > 1000) AS high_order_count,  
    (SELECT COUNT(*) FROM orders WHERE order_amount > 500 AND order_amount <= 1000) AS medium_order_count,  
    (SELECT COUNT(*) FROM orders WHERE order_amount <= 500) AS low_order_count  
FROM orders;

使用CASE WHEN语句,我们可以将上述子查询转换为以下查询:

SELECT  
    SUM(CASE WHEN order_amount > 1000 THEN 1 ELSE 0 END) AS high_order_count,  
    SUM(CASE WHEN order_amount > 500 AND order_amount <= 1000 THEN 1 ELSE 0 END) AS medium_order_count,  
    SUM(CASE WHEN order_amount <= 500 THEN 1 ELSE 0 END) AS low_order_count  
FROM orders;

在上述查询中,我们使用SUM函数结合CASE WHEN语句来根据不同的条件统计订单数量。对于每个级别,我们使用相应的条件来计算订单数量。

这个查询将返回与之前子查询相同的结果,但是使用了CASE WHEN语句进行条件统计,避免了使用多个子查询。CASE WHEN的统计SQL语句性能较高,主要是因为它能够避免全表扫描、提高查询效率和更好的索引利用,这种方式在处理大型数据集时可能更高效。

使用CASE WHEN常用写法

创建一张测试表 test_table,如图是表中的信息:

(1)该CASE语句评估每个条件,并在条件为true时返回相应的结果。如果没有条件为true,则返回ELSE结果。

-- 这种形式的CASE语句评估每个条件,并在条件为true时返回相应的结果。
-- 如果没有条件为true,则返回ELSE结果。
SELECT username as '姓名', score as '成绩', score_level '等级',
CASE
   WHEN score >= 90 THEN '优秀'
   WHEN score >= 80 THEN '良好'
   WHEN score >= 60 THEN '一般'
   ELSE '不及格'
END AS '描述'
FROM test_table order by score desc;

(2)该CASE语句将表达式与每个值进行比较,并在找到匹配项时返回相应的结果。如果未找到匹配项,则返回ELSE结果。

-- 这种形式的CASE语句将表达式与每个值进行比较,并在找到匹配项时返回相应的结果。
-- 如果未找到匹配项,则返回ELSE结果。
SELECT username as '姓名', score as '成绩',
case score_level
   WHEN 'A' THEN '优秀'
   WHEN 'B' THEN '良好'
   ELSE '不及格'
END AS '描述'
FROM test_table order by score desc;

(3)该CASE语句可以在SELECT查询中用于对所选列执行条件计算或转换。

-- SELECT查询中的CASE语句:
-- CASE语句可以在SELECT查询中用于对所选列执行条件计算或转换
SELECT username as '姓名', score as '成绩',
   CASE   
   WHEN score > 60 THEN '及格' ELSE '不及格'  
   END AS '说明'  
FROM test_table order by score desc;

(4)该CASE语句可以在UPDATE查询中使用,以根据某些条件有条件地更新值。

-- UPDATE查询中的CASE语句:
-- CASE语句可以在UPDATE查询中使用,以根据某些条件有条件地更新值。
UPDATE test_table  
SET score = CASE  
  WHEN score > 60 THEN score + 10
  ELSE score - 10 
  END  
WHERE score > 50;

使用CASE WHEN语句进行数据统计,对不同条件的数据进行分类、分组和聚合

当前数据表中的信息:

(1)根据学科类别统计学科人员数量

-- 根据学科类别统计学科人员数量
SELECT subject '学科',  
       COUNT(*) AS '数量'  
FROM test_table  
GROUP BY CASE  
           WHEN subject LIKE '数%' THEN '理科'  
           WHEN subject LIKE '语%' THEN '文科'  
           ELSE '其它'  
       END;

(2)查询每个学科的人数以及计算每个学科的平均值

-- 查询每个学科的人数以及计算每个学科的平均值
SELECT subject '学科', count(1) '人数', 
       AVG(score) AS '平均成绩'
FROM test_table  
WHERE score > 30
GROUP BY CASE  
           WHEN subject LIKE '数%' THEN '理科'  
           WHEN subject LIKE '语%' THEN '文科' 
           ELSE '其它'  
       END;

(3)查询统计数据表中最高分、平均分、各个学科总分数

-- 查询统计数据表中最高分、平均分、各个学科总分数
  SELECT sum(score) '总分数',  
   SUM(CASE WHEN subject LIKE '数%' THEN score ELSE 0 END) AS '数学总分数',  
   SUM(CASE WHEN subject LIKE '语%' THEN score ELSE 0 END) AS '语文总分数',
   SUM(CASE WHEN subject LIKE '自%' THEN score ELSE 0 END) AS '自然总分数',
   AVG(CASE WHEN score > 0 THEN score END) AS '平均分',  
   MAX(CASE WHEN score > 0 THEN score END) AS '最高分'  
  FROM test_table;

以上使用都是CASE WHEN进行数据处理时的常用写法,可以根据具体的业务需求选择合适的用法来优化数据统计查询信息。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/987767.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

深度学习:基于循环神经网络RNN实现自然语言生成

目录 1 循环神经网络介绍 1.1 什么是循环神经网络 1.2 RNN的网络结构 1.3 RNN的工作原理 ​编辑 1.4 RNN的应用场景 2 基于RNN实现语句生成 2.1 句子生成介绍 2.2 基于pytorch实现语句生成 2.3 完整代码 2.4 该模型的局限 3 总结 1 循环神经网络介绍 1.1 什么是循环…

Anaconda - 操作系统安装程序 简要介绍

Anaconda 简要介绍 1. Anaconda 简介2. Anaconda 体系结构3. Anaconda 开发模型4. Anaconda 启动概述5. Anaconda 源码1. 接口2. 自定义组件3. 硬盘分区&#xff1a;使用python-blivet包4. Bootloader5. 各个步骤的配置&#xff1a;6. 安装软件包&#xff1a;7. 安装控制&#…

华为强势回归,苹果iPhone15ProMax独占潜望式镜头,预计销量受损

9月8日消息&#xff0c;据集邦咨询发布的产业洞察报告显示&#xff0c;苹果即将发布的iPhone 15 Pro Max将会独占潜望式镜头&#xff0c;该机型的占比预计将会达到40%左右。报告同时预估&#xff0c;今年iPhone 15系列手机的出货量将达到8000万&#xff0c;相比去年同期增长6%以…

无需公网IP教你如何外网远程访问管家婆ERP进销存

文章目录 前言 1.管家婆服务2. 内网穿透2.1 安装cpolar内网穿透2.2 设置远程访问 3. 固定访问地址4. 配置固定公网访问地址 前言 管家婆辉煌系列产品是中小企业进销存、财务管理一体化的典范软件&#xff0c;历经十余年市场的洗礼&#xff0c;深受广大中小企业的欢迎&#xff…

冠达管理:不要误读“房贷利率降低”

最近&#xff0c;人人都知道房贷利率降了&#xff0c;但如果细问“怎么降的、哪些城市降了、将产生何种影响”&#xff0c;恐怕不少人都是水中望月。正因此&#xff0c;部分房地产中介、营销机构利用购房者的信息不对称劣势&#xff0c;刻意夸张房贷利率下降关于楼市价格的影响…

16 除自身以外数组的乘积

除自身以外数组的乘积 题解1 前缀积*后缀积题解2 空间优化 给你一个整数数组 nums&#xff0c;返回 数组 answer &#xff0c;其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数…

YAPI的搭建和使用

https://www.cnblogs.com/yehuisir/p/12315137.html 1、#进入数据库 mongo 2、#进入admin库 use admin 3、#添加一个用户root&#xff08;此步骤可不执行&#xff09; db.createUser({user:"root",pwd:"123456abc.COM",roles:["root"]}) …

【合作 】联通、壳牌、联想、国金证券等众多企业签约 Eolink !

联通、壳牌、联想、华润置地、中国铁塔等多家知名企业签约 Eolink&#xff0c;携手落地 API 全生命周期管理&#xff0c;感谢广大企业对 Eolink 的信任和选择&#xff01; Eolink 致力于为企业提供最全面的 API 研发管理解决方案&#xff0c;提供高效、可靠的工具以及服务&…

深入了解 Axios 的 put 请求:使用技巧与最佳实践

在前端开发中&#xff0c;我们经常需要与后端服务器进行数据交互。其中&#xff0c;PUT 请求是一种常用的方法&#xff0c;用于向服务器发送更新或修改数据的请求。通过发送 PUT 请求&#xff0c;我们可以更新服务器上的资源状态。 Axios 是一个流行的 JavaScript 库&#xff0…

解析进程复制:父子进程内存地址的神秘之处

当涉及到进程复制时&#xff0c;有时会出现一个令人困惑的现象&#xff1a;在父进程和子进程中&#xff0c;某些变量的内存地址似乎是相同的&#xff0c;尽管它们实际上是独立的进程。下面我将简单解释这个现象以及背后的原因。 进程复制&#xff1a;父子进程的神秘关系 在多…

Vue3统一导出局部组件和全局组件

局部组件统一导出 components新增ComponentA.vue、ComponentB.vue两个组件 新增index.js进行组件统一导入 import ComponentA from ./ComponentA.vue import ComponentB from ./ComponentB.vueexport {ComponentA,ComponentB }使用 <template><ComponentA /><…

leetcode 150.逆波兰表达式求值

⭐️ 题目描述 &#x1f31f; leetcode链接&#xff1a;逆波兰表达式求值 思路&#xff1a; 假设这样一组表达式 { "2" , "1" , "" , "3" , "*" } 这是一种后缀表达式&#xff0c;首先我们准备一个栈&#xff0c;当如果不是…

电动汽车行业,这个技能绝了!

在当今不断演变的汽车工业中&#xff0c;电动汽车已经崭露头角&#xff0c;并迅速改变着我们的出行方式。这种创新的交通方式不仅减少了尾气排放&#xff0c;还为我们带来了更加环保和可持续的未来愿景。在电动汽车的核心&#xff0c;蓄电池技术正发挥着至关重要的作用。 然而&…

阿里巴巴推出D.Design文生图网站(免费10-20张图)

简介&#xff1a; d.design是阿里巴巴推出的一个基于人工智能的设计工具&#xff0c;可以帮助用户轻松创建3D模型和场景。该工具提供了丰富的素材库和功能&#xff0c;可以满足用户的各种需求。 ​堆友堆友是Alibaba Design打造的设计师全成长周期服务平台&#xff0c;围绕品质…

Python中处理异常和错误

作为一种强大且灵活的编程语言&#xff0c;Python 提供了许多机制来处理程序运行过程中可能出现的异常和错误。本文将详细介绍如何在 Python 中以“优雅、高效”的方式进行异常处理&#xff0c;并提供实用技巧帮助开发者更好地应对各种情况。无论您是初学者还是有经验的开发人员…

上行取消指示 DCI format 2_4

上篇介绍了DCI format 2_1的DL传输中断的内容&#xff0c;这篇就看下DCI format 2_4有关的UL 传输取消机制&#xff0c;值得注意的是这里的UL传输针对的是PUSCH和SRS传输。 UL cancellation DCI format 2_4相关机制引入的背景与DCI format 2_1一样&#xff0c;都是因为URLLC和e…

3ds max插件CG MAGIC中的室外功能可以高效出图吗?

使用3ds Max高效出图秘诀有没有什么秘诀呢&#xff1f;如何做到快速出图呢&#xff1f; 3ds max插件CG MAGIC中的室外功能可以高效出图吗&#xff1f; CG MAGIC 是一款基于3DS max深入开发的智能辅助设计插件。 自从CG Magic专业版上线之后&#xff0c;小伙伴们对新功能诀窍…

当浏览器切换到其他标签页或者最小化时,你的js定时器还准时吗?

最近一个项目遇到这个问题&#xff0c;获取北斗授时服务器时间校准本地时间&#xff0c;定时器是需要用到的&#xff0c;大致步骤分为以下几点&#xff1a; 1.定时请求服务器时间 2.根据获取到接口返回时间自动累加 参考&#xff1a; vue.js和原生js时间自动累加功能_js时间…

windows 下docker安装宝塔镜像 宝塔docker获取镜像

1. docker 安装宝塔 打开链接&#xff1a;https://www.docker.com/get-started&#xff0c;找对应的版本下载docker&#xff0c;安装docker打开百度云盘&#xff1a;链接&#xff1a;https://pan.baidu.com/s/1DGIjpKkNDAmy4roaKGLA_w 提取码&#xff1a;u8bi 2. 设置镜像 点…

LeetCode刷题笔记【31】:动态规划专题-3(整数拆分、不同的二叉搜索树)

文章目录 前置知识343. 整数拆分题目描述解题思路代码进一步优化 96.不同的二叉搜索树题目描述解题思路代码优化改进 总结 前置知识 参考前文 参考文章&#xff1a; LeetCode刷题笔记【29】&#xff1a;动态规划专题-1&#xff08;斐波那契数、爬楼梯、使用最小花费爬楼梯&…