SQL 分组统计去重有条件的过滤

article/2025/10/17 6:02:42

见字如面,如标题拆分:

  • 分组   GROUP BY field_name
  • 统计   COUNT(field_name)
  • 去重  DISTINCT  field_name
  • 条件过滤     CASE WHEN   age > 18 THEN  age  END

示例:

前序:

        表结构

CREATE TABLE `data_table_name` (`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',`username` varchar(50) CHARACTER SET utf8 NOT NULL DEFAULT '' COMMENT '用户姓名',`age` tinyint(3) NOT NULL DEFAULT '0' COMMENT '年龄',`is_online` tinyint(1) NOT NULL DEFAULT '1' COMMENT '是否在线 1:在线 2:离线 ',`create_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin COMMENT='测试数据表';

 表数据:

 

 

二、 需求

        1、统计所有用户不同年龄段的数量,以年龄为维度分组

select count(age) from data_table_name group by age;

        结果1: 

 

 

 

         2、统计所有用户不同年龄段的数量,以年龄为维度分组且以创建时间去重

select *, count(DISTINCT create_time) from data_table_name group by age;

结果2:

 

3、统计所有用户不同年龄段的数量,以年龄为维度分组且以创建时间去重,并且创建时间大于 > 1653903132

select *,
count(DISTINCT case when create_time > 1653903132 then create_time end) as num from data_table_name group by age;

        结果3:                 

 

4、 统计所有用户不同年龄段的数量,以年龄为维度分组且以创建时间去重,并且创建时间大于 > 1653903132 and is_online = 1

select *, count(DISTINCT case when create_time > 1653903132 and is_online = 1 then create_time end) as num from data_table_name group by age;

         结果4:     

 

 

以上,需求千息万变,万变不离其宗。

 

 我为人人,人人为我,美美与共,天下大同。


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

相关文章

mysql sql 分组求和函数_SQL分组函数group by和聚合函数(COUNT、MAX、MIN、AVG、SUM)的几点说明...

1 分组聚合的原因 SQL中分组函数和聚合函数之前的文章已经介绍过,单说这两个函数有可能比较好理解,分组函数就是group by,聚合函数就是COUNT、MAX、MIN、AVG、SUM。 拿上图中的数据进行解释,假设按照product_type这个字段进行分组,分组之后结果如下图。 SELECT product_ty…

SQL分组取最大值的方法

一、业务需求 1.1.数据表展示 1.2.查询要求 要求查询所有字段,并按iceName,orderPath,exceptionType分组,在分组时取systemTime值最大的那条数据 注:本文适用于查询多字段的查询,单纯的 select MAX(字段A) 或select B,MAX(字段…

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

说明 最近遇到这么一个需求&#xff1a;统计区间在0-2000,2000-3000,3000-4000,4000-5000,5000工资的人数。 快速开始 数据如下&#xff1a; 开始看到这个问题&#xff0c;想都没想就开始写了下面的代码&#xff1a; SELECT casewhen salary < 2000 then [0, 2000)when …

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…