SQL分组后将不存在的组记为0

article/2025/10/17 6:07:04

说明

最近遇到这么一个需求:统计区间在0-2000,2000-3000,3000-4000,4000-5000,5000+工资的人数。

快速开始

数据如下:

开始看到这个问题,想都没想就开始写了下面的代码:

SELECT casewhen salary < 2000 then '[0, 2000)'when salary >= 2000 and salary < 3000 then '[2000, 3000)'when salary >= 3000 and salary < 4000 then '[3000, 4000)'when salary >= 4000 and salary < 5000 then '[4000, 5000)'when salary >= 5000 then '[5000+)'end c,COUNT(*)
FROM salary_list
GROUP BY c

执行结果:

但其实我们要的结果是

[0,2000]             0
[2000,3000)       3
[3000,4000)       2
[4000,5000)       0
[5000+)              1

那么这个SQL不对啊!这个SQL把没有数据的组给吃了!所以我们得想办法将缺失的组补回来!

解决方案1(推荐)

参考了sql 分组统计,数据为空时显示0,我将SQL改为了下面的

select c,sum(co)
from
(SELECT casewhen salary < 2000 then'[0, 2000)'when salary >= 2000 and salary < 3000 then'[2000, 3000)'when salary >= 3000 and salary < 4000 then'[3000, 4000)'when salary >= 4000 and salary < 5000 then'[4000, 5000)'when salary >= 5000 then'[5000+)'end c,COUNT(*) co
from salary_list
group by c
UNION SELECT '[0, 2000)' as c,'0' as co
UNION SELECT '[2000, 3000)' as c,'0' as co
UNION SELECT '[3000, 4000)' as c,'0' as co
UNION SELECT '[4000, 5000)' as c,'0' as co
UNION SELECT '[5000+)' as c,'0' as co) as temp
group by c

分析:这个方法非常的巧妙,使用我们前面的方法分组后再 UNION(并集) 我们需要的组并将新加的数据记为0,然后再次使用group按照名称再次分组(得到分组为空的情况),然后再使用sum将我们之前计算的人数再+0就能得到我们所需要的结果

解决方案2(推荐)

SELECT count(case when salary <2000 then 1 end) as '[0, 2000)',count(case when salary >=2000 and salary <3000 then 1 end) as '[2000, 3000)',count(case when salary >=3000 and salary <4000 then 1 end) as '[3000, 4000)',count(case when salary >=4000 and salary <5000 then 1 end) as '[4000, 5000)',count(case when salary >=5000 then 1 end) as '[5000+)'
from salary_list

分析:既然是group by导致的分组丢失,那不如自己写分组,也就是说在select count的时候在count里自己来写分组的条件(这种方法应该比较容易理解)

解决方案3(不推荐)

通过方案1得到的一种扩展性思维,我们也可以再创建一张临时表,包括所有的分组名称和统计值(记为0),然后将我们第一个SQL执行的结果和这张临时表进行left join或者right join连接起来(这个方案操作太麻烦,就不讨论了)

 


http://chatgpt.dhexx.cn/article/BR5SKrAa.shtml

相关文章

SQL 分组条件深入剖析

问题 在 stackoverflow 网站上看到这样一个 SQL 分组条件的需求&#xff0c;需求看似挺简单&#xff0c;但能把 SQL 写正确对于新手来说也不容易&#xff0c;我们拿过来深入剖析一下&#xff0c;数据如下&#xff1a; 需求是查找只有Ready 状态的设备。 解答 自然思路&#xff…

SQL分组排序函数(组内分别排序)

建表并插入数据 -- 部门表 create table dept( deptno int primary key auto_increment, -- 部门编号 dname varchar(14) , -- 部门名字 loc varchar(13) -- 地址 ) ; -- 员工表 create table emp( empno int primary key auto_increment,-- 员工编号 …

sql 分组 行列转换

sql 分组 & 行列转换 文章目录 sql 分组 & 行列转换1、groupby&#xff08;配合组合函数使用&#xff09;2、Sql的行列转换 - 纵横表1&#xff09;纵表转横表2&#xff09;横表转纵表 sql语句教程参考W3C School - SQL 教程 就够了 1、groupby&#xff08;配合组合函数…

SQL:分组数据

分组数据&#xff1a; A. SQL Server Group By语句 Group By 从字面意义上理解就是根据“By”指定的规则对数据进行分组&#xff0c;所谓的分组就是将一个“数据集” 划分成若干个“小区域”&#xff0c;然后针对若干个“小区域”进行数据处理。 以下是 GROUP BY 子句的语…

SQL语言中的分组数据

&#xff08;1&#xff09;group by子句 group by 根据by指定的规则对数据进行分组。 分组&#xff1a;即将一个“数据集”划分成若干个“小区域”&#xff0c;再对若干个“小区域”进行数据处理。 语法&#xff1a; group by 子句为列中的每个值组合生成一个组。 group by子…

SQL分组指南

目录 什么是SQL分组&#xff1f; SQL GROUP BY和Sum 排序分组结果 HAVING和GROUP BY 包含多个表的GROUP BY 按SUM()排序 带有表达式的GROUP BY SQL GROUP BY与DISTINCT 结论 什么是SQL分组&#xff1f; 在SQL中&#xff0c;分组是唯一的列值组合。当查询具有GROUP BY…

单例模式的使用和应用场景

1.概念 标题单例模式&#xff1a;单例指的是单实例&#xff0c;一个类中有且仅有创建一个实例 单例模式的应用场景&#xff1a;windows的任务管理器(不可打开两次吧)、回收站等 单例模式应用一般发现在以下条件下&#xff1a; servlet单例、struts2多例、springmvc单例 &…

单例模式实战应用

理论 什么是单例模式 保证整个系统中一个类只有一个对象的实例&#xff0c;实现这种功能的方式就叫单例模式 常用的 service 和 dao 层的对象通常都是单例的&#xff0c;而多例则指每个请求用一个新的对象来处理&#xff0c;比如 action spring 中的 bean 和 spring mvc 中…

单例模式php应用场景,php单例模式 使用场景和使用方法

一个类只有一个对象实例 1、含义 作为对象的创建模式&#xff0c;单例模式确保某一个类只有一个实例&#xff0c;而且自行实例化并向整个系统全局地提供这个实例。它不会创建实例副本&#xff0c;而是会向单例类内部存储的实例返回一个引用。 2、单例模式的三个要点&#xff1a…

Java设计模式及应用场景之《单例模式》

文章目录 一、单例模式定义二、单例模式的结构和说明三、懒汉式和饿汉式的实现1、懒汉式2、饿汉式 四、懒汉式和饿汉式的优缺点五、双重检查加锁方式的实现六、类级内部类方式的实现七、枚举方式的实现 (最佳方式)八、单例模式的应用场景 一、单例模式定义 保证一个类只能有一个…

一文带你了解 Java 五种单例模式的实现方式以及应用场景

单例模式 什么是单例模式 类的单例设计模式&#xff0c;就是采取一定的方法保证在整个软件系统中&#xff0c;某个类只能存在一个对象实例&#xff0c;并且这个类会提供一个获取对象实例的方法。 思路&#xff1a;如果让一个类在一个虚拟机里面只能产生一个对象&#xff0c;就…

js设计模式之 单例模式与应用场景

1.介绍 单例模式&#xff08;Singleton Pattern&#xff09;是设计模式中最简单的设计模式之一。这种类型的设计模式属于创建型模式&#xff0c;它提供了一种创建对象的最佳方式。 这种模式涉及到一个单一的类&#xff0c;该类负责创建自己的对象&#xff0c;同时确保只有单个…

单例模式的理解?单例模式如何实现?单例模式应用场景

说说你对单例模式的理解&#xff1f;如何实现&#xff1f; 一、是什么 单例模式&#xff08;Singleton Pattern&#xff09;&#xff1a;创建型模式&#xff0c;提供了一种创建对象的最佳方式&#xff0c;这种模式涉及到一个单一的类&#xff0c;该类负责创建自己的对象&…

设计模式之单例模式应用场景篇

应用场景 我们为什么要使用单例模式呢&#xff1f;它有什么好处&#xff1f; &#xff08;一&#xff09;单例模式可以让我们只创建一个对象从而避免了频繁创建对象导致的内存消耗和垃圾回收。 Servlet是单例模式&#xff0c;我们只需要创建一个Servlet&#xff0c;然后接收请求…

关于getText()的小问题

由一个作业开始的,整完广度优先小作业的时候开始是在代码中指定值进行寻找路径,后面想想还是弄两文本框输入起点和终点更灵活一点好了。谁知道这个JTextField真的让我崩溃了 怎么说应该是我对Java的基础知识没有进行深入了解吧,好吧,我是在今天才知道getText()是在监听事件…

js gettext

test.php 1 <?php2 $localezh_CN;3 if(isSet($_GET["locale"]))$locale $_GET["locale"];4 ?>5 <html>6 <head>7 <link rel"gettext" type"application/x-po" href"./locale/<?php echo $locale ?&…

关于Java getText()方法的问题

这是一个登陆界面的鼠标事件&#xff0c;获取文本区t61的内容&#xff0c;与用户姓名比对&#xff0c;同时验证登陆密码&#xff0c;但是用户姓名比对一直不成功&#xff0c;导致鼠标事件不能反映&#xff0c;页面不能跳转&#xff0c;想知道为什么&#xff0c;求大佬指点。 p…

java的gettext_JAVA里 getText() 是什么意思,怎么用?

展开全部 JAVA里 getText() 的意思是&#xff1a;返回数据窗口控件中 悬浮在当前行列之上的32313133353236313431303231363533e4b893e5b19e31333431366266编辑框中的文本。 在用户修改数据窗口中某项的值时&#xff0c;实际上首先在悬浮 在当前项上的编辑框中进行修改&#xff…

python gettext的使用方法

app.py 里面的print函数输出内容&#xff0c;是会更据你选择的语言平台而改变 将app.py生成.po文件(或者生成.pot文件)&#xff0c;如果是.pot文件需要重命名为.po pygettext.py安装python的时候就自己带着有&#xff0c;去你的安装路径找 python &#xff08;这一步&#xff…

getText()和getText().toString()

在deadline只有一根咪咪的距离时&#xff0c;我就直接吐槽了。 一个组件&#xff0c;比方说EditView&#xff0c;它的getText()和getText().toString()这两种想得到这个组件中的内容的方法是不一样的&#xff0c;我在用startActivityForResulr()之后接收到来自另一个activity的…