【MySQL】聚合查询与分组查询
我们先重建一个test库,在test库里新建一个people表(包含序列号,姓名,工资),再往表该表里新增六条数据:
mysql> drop database if exists test; Query OK, 1 row affected (0.07 sec)mysql> create database test; Query OK, 1 row affected (0.00 sec)mysql> use test; Database changed mysql> create table people(-> id int primary key auto_increment,-> name varchar(20),-> careen varchar(20),-> salary int-> ); Query OK, 0 rows affected (0.05 sec)mysql> insert into people value(null,"张三","老师",3000); Query OK, 1 row affected (0.01 sec)mysql> insert into people value(null,"李四","老师",4000); Query OK, 1 row affected (0.01 sec)mysql> insert into people value(null,"王五","老师",5000); Query OK, 1 row affected (0.01 sec)mysql> insert into people value(null,"赵六","医生",60000); Query OK, 1 row affected (0.00 sec)mysql> insert into people value(null,"小七","医生",70000); Query OK, 1 row affected (0.00 sec)mysql> insert into people value(null,null,null,null); Query OK, 1 row affected (0.00 sec)mysql> select * from people; +----+--------+--------+--------+ | id | name | careen | salary | +----+--------+--------+--------+ | 1 | 张三 | 老师 | 3000 | | 2 | 李四 | 老师 | 4000 | | 3 | 王五 | 老师 | 5000 | | 4 | 赵六 | 医生 | 60000 | | 5 | 小七 | 医生 | 70000 | | 6 | NULL | NULL | NULL | +----+--------+--------+--------+ 6 rows in set (0.00 sec)接下来我们就针对该表进行聚合查询操作~
♫聚合查询
前面我们所用的基础的查询操作只能对每行进行独立的查询操作,而要是想要查询的结果是该列所有数据的平均值,最大或最小值,则需要使用聚合查询才能做到。聚合查询需要用到聚合函数,因此,要学会聚合查询,首先得先了解下MySQL中的聚合函数。
♪聚合函数
常见的聚合函数有以下几种:
函数 描述 COUNT([DISTINCT] expr) 返回查询到的数据的数量AVG([DISTINCT] expr) 返回查询到的数据的总和,不是数字没有意义SUM([DISTINCT] expr) 返回查询到的数据的平均值,不是数字没有意义MAX([DISTINCT] expr) 返回查询到的数据的最大值,不是数字没有意义MIN([DISTINCT] expr) 返回查询到的数据的最小值,不是数字没有意义知道了聚合函数,接下来就可以使用这些聚合函数进行聚合查询操作了。
♪查询表的行数
查询表的行数需要用到聚合函数count():
语法:select count(*) from 表名;
mysql> select count(*) from people; +----------+ | count(*) | +----------+ | 6 | +----------+ 1 row in set (0.00 sec)此外count(常量)也能查询表的行数:
语法:select count(常量) from 表名;
mysql> select count(1) from people; +----------+ | count(1) | +----------+ | 6 | +----------+ 1 row in set (0.00 sec)注:
①.count(1)和count(*)的实现方式略有不同,count(1)是对表中的每一行都执行一次计数操作,而count(*)则是对整个表执行计数操作
②.查询表的行数包括全为NULL的行
♪查询表某一列的行数
单独查询表某一列有几行也是需要用到count():
语法:select count(列名/表达式) from 表名;
mysql> select count(name) from people; +----------------+ | count(name) | +----------------+ | 5 | +----------------+ 1 row in set, 5 warnings (0.00 sec)注:查询某一列的行数不会包含NULL数据
♪查询表某一列数据的和
要想查询结果是某一列的数据和就需要用到聚合函数sum():
语法:select sum(列名/表达式) from 表名;
mysql> select sum(salary) from people; +-------------+ | sum(salary) | +-------------+ | 142000 | +-------------+ 1 row in set (0.00 sec)注:只能查询数字列的和,不能求字符串/日期的和
♪查询表某一列数据的平均值
要查询某一列数据的平均值就需要用到聚合函数avg():
语法:select avg(列名/表达式) from 表名;
mysql> select avg(salary) from people; +-------------+ | avg(salary) | +-------------+ | 28400.0000 | +-------------+ 1 row in set (0.00 sec)注:只能查询数字列的平均值
♪查询表某一列数据的最大值
要查询某一列数据的最大值就需要用到聚合函数max():
语法:select max(列名/表达式) from 表名;
mysql> select max(salary) from people; +-------------+ | max(salary) | +-------------+ | 70000 | +-------------+ 1 row in set (0.00 sec)注:只能查询数字列的最大值
♪查询表某一列数据的最小值
要查询某一列数据的最小值就需要用到聚合函数min():
语法:select min(列名/表达式) from 表名;
mysql> select min(salary) from people; +-------------+ | min(salary) | +-------------+ | 3000 | +-------------+ 1 row in set (0.00 sec)注:只能查询数字列的最小值
上面聚合查询的对象是所有人,要想查询的对象为同一职业的人,可以通过group by子句来实现。
♫分组查询
♪group by子句
select中使用 group by 子句可以对指定列进行分组查询。需要满足:使用group by 进行分组查询时,select 指定的字段必须是 “ 分组依据字段 ” ,其他字段若想出现在 select 中则必须包含在聚合函数中。语法:select 列名,聚合函数,... from 表名 group by 列名;
-- 查询每种职业的最高薪资 mysql> select careen,max(salary) from people group by careen; +--------+-------------+ | careen | max(salary) | +--------+-------------+ | NULL | NULL | | 医生 | 70000 | | 老师 | 5000 | +--------+-------------+ 3 rows in set (0.01 sec)如果是不带聚合函数的分组查询,查询结果为每个分组的第一条记录:
mysql> select * from people group by careen; +----+--------+--------+--------+ | id | name | careen | salary | +----+--------+--------+--------+ | 6 | NULL | NULL | NULL | | 4 | 赵六 | 医生 | 60000 | | 1 | 张三 | 老师 | 3000 | +----+--------+--------+--------+ 3 rows in set (0.01 sec)分组查询还可以对分组前指定条件或对分组后指定条件:
♪分组前指定条件
对筛选出来的数据进行分组查询:
语法:select 列名,聚合函数,... from 表名 group by 列名 where 指定条件;
-- 取所有工资大于3000的人,对这类人按照对应职业进行分组查询 mysql> select careen,avg(salary) from people where salary>3000 group by careen; +--------+-------------+ | careen | avg(salary) | +--------+-------------+ | 医生 | 65000.0000 | | 老师 | 4500.0000 | +--------+-------------+ 2 rows in set (0.02 sec)♪分组后指定条件
对分组查询后的数据进行筛选:
语法:select 列名,聚合函数,... from 表名 group by 列名 having 指定条件;
-- -- 按照职业进行分组查询,取查询结果中平均工资大于5000的职业 mysql> select careen,avg(salary) from people group by careen having avg(salary)>5000; +--------+-------------+ | careen | avg(salary) | +--------+-------------+ | 医生 | 65000.0000 | +--------+-------------+ 1 row in set (0.00 sec)
相关文章:
【MySQL】聚合查询与分组查询
我们先重建一个test库,在test库里新建一个people表(包含序列号,姓名,工资),再往表该表里新增六条数据: mysql> drop database if exists test; Query OK, 1 row affected (0.07 sec)mysql>…...
RFID技术在锂电池生产线自动化应用
随着电动汽车和能源储存系统市场的不断扩大,锂离子电池作为其核心部件,以其高能量密度、长寿命等优点成为了主流选择。而对于锂电池智能化、高效化生产有着更高的要求,RFID技术的使用,将大幅度提高锂电池的生产产能,从…...
钢筋智能测径仪 光圆与带肋钢筋均可检测!
在一个大规模、高效、连续的工业生产中,制造业正朝着自动化方向快速优化发展,这种自动化的生产需要快速、准确地分析控制生产工艺中的参数,超差及时提示,为操作工对工厂的运行和自我调节做出快速反应,人工操作越来越不…...
docker--在Anaconda jupyter 容器中使用oracle数据源时,Oracle客户端安装配置及使用示例
配置oracle 11.2 客户端 将instantclient-basic-linux.x64-11.2.0.4.0.zip解压至/home/jupyter/oracle/将instantclient-sqlplus-linux.x64-11.2.0.4.0.zip解压/home/jupyter/oracle/【可选,提供sqlplus命令】复制【操作系统一般都有安装libaio.so】 cp /usr/lib64…...
can的波特率/比特率
can控制器只需要进行少量的设置就可以进行通信,就像RS232那样。其中较难设置的部分就是通信波特率的计算。can总线能够在一定范围内容忍总线上can节点的通信波特率的偏差,这种技能使得can总线有很强的容错性,同时也降低了对每个节点的振荡器精…...
项目经理涨薪秘籍!技巧都在这里了
好奇前辈们是如何带好团队、做出成功项目,从而升职加薪,成为高级项目经理或项目管理主管的?这是绝大多数新手PM最关注的事情。今天小编给大家揭秘! 一、刚入门如何进阶 从入门的项目管理者发展到中级的项目管理者,重…...
甘特图组件DHTMLX Gantt示例 - 如何有效管理团队工作时间?(一)
如果没有有效的时间管理工具,如工作时间日历,很难想象一个项目如何成功运转。这就是为什么我们的开发团队非常重视项目管理,并提供了多种选择来安排DHTMLX Gantt的工作时间。使用DHTMLX Gantt这个JavaScript库,您可以创建一个强大…...
健效达海豚妈妈儿保项目推介会盛大启幕,聚焦互联网+精准医疗
2023年10月12日,由上海健启星科技发展有限公司和北京安智因生物技术有限公司联合主办的“2023互联网精准医学平台助力基层医疗|海豚妈妈儿保项目推介会”在中国苏州盛大启幕。 本次项目推介会得到国内行业专家、权威学者、国内知名三甲名医教授、头部企业、学术大咖…...
使用XLua在Unity中获取lua全局变量和函数
1、Lua脚本 入口脚本 print("OK") --也会执行重定向 require("Test") 测试脚本 print("TestScript") testNum 1 testBool true testFloat 1.2 testStr "123"function testFun()print("无参无返回") endfunction te…...
springboot项目集成kafka,并创建kafka生成消息线程池
效果图: 步骤1:添加依赖 <!-- kafka依赖 --><dependency><groupId>org.apache.kafka</groupId><<...
PreScan与MATLAB联合仿真报错
一、 问题: Error:Matlab ||和&&运算符的操作数必须能够转换为逻辑标量值 二、解决办法 必须安装VS2013(我装的VS2017不行的),然后重启prescan和MATLAB,编译通过,界面如下: 三、VS…...
ros学习笔记(1)Mac本地安装虚拟机,安装Ros2环境
Ros与Linux的关系 Ros环境基于Linux系统内核 我们平时用的是Linux发行版,centos,ubuntu等等,机器人就用了ubunut 有时候我们经常会听到ubunue的版本,众多版本中,有一些是长期维护版TLS,有一些是短期维护…...
史上最强,Jmeter性能测试-性能场景设计实例(详全)
目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 1、性能测试需求 …...
【vim 学习系列文章 7-- vim vnormap nnoremap nmap map inoremap 区别】
文章目录 1.1 vim 递归映射和非递归映射1.1.1 vim 可视模式 1.2 map nmap vnormap nnoremap inoremap 区别 1.1 vim 递归映射和非递归映射 递归映射和非递归映射是 Vim 中两种不同的键盘映射方式。 递归映射(recursive map)是指在定义键盘映射时&#x…...
[ERROR] COLLATION ‘utf8_unicode_ci‘ is not valid for CHARACTER SET ‘latin1‘
[ERROR] COLLATION utf8_unicode_ci is not valid for CHARACTER SET latin1错误来源是: 跟着b站的谷粒商城项目做,前面的视频中设置了数据库的字符集编码,但是后面自己发现了MySQL容器重启报错,不停的在重启 查看log信息可以使用…...
基于rancher安装部署k8s
基础配置 systemctl stop firewalld && systemctl disable firewalld setenforce 0 sed -i s/SELINUXenforcing/SELINUXdisabled/ /etc/selinux/configvi /etc/hosts ip1 node1 ip2 node2 ip3 node3#免密登录 ssh-keygenssh-copy-id -i ~/.ssh/id_rsa.pub 普通用户ip1…...
保姆级微服务部署教程
大家好,我是鱼皮。 项目上线是每位学编程同学必须掌握的基本技能。之前我已经给大家分享过很多种上线单体项目的方法了,今天再出一期微服务项目的部署教程,用一种最简单的方法,带大家轻松部署微服务项目。 开始之前,…...
springboot 定时任务
springboot 定时任务 在Spring Boot中,你可以使用Spring的Scheduled注解来创建定时任务。以下是一个简单的示例: 首先,你需要在Spring Boot的主类上添加EnableScheduling注解以启用定时任务功能。 import org.springframework.boot.Spring…...
【大数据】HBase入门指南
原创不易,注重版权。转载请注明原作者和原文链接 文章目录 HBase特性Hadoop的限制基本概念NameSpaceTableRowKeyColumnTimeStampCell 存储结构HBase 数据访问形式架构体系HBase组件HBase读写流程读流程写流程 MemStore Flush参数说明 StoreFile Compaction参数说明触…...
零售数据分析模板鉴赏-品类销售结构报表
不管是服装零售,还是连锁超市或者其他,只要是零售行业就绕不过商品数据分析,那么商品数据分析该怎么做?奥威BI的零售数据分析方案早早就预设好相关报表模板,点击应用后,一键替换数据源,立得新报…...
Python|GIF 解析与构建(5):手搓截屏和帧率控制
目录 Python|GIF 解析与构建(5):手搓截屏和帧率控制 一、引言 二、技术实现:手搓截屏模块 2.1 核心原理 2.2 代码解析:ScreenshotData类 2.2.1 截图函数:capture_screen 三、技术实现&…...
Vue记事本应用实现教程
文章目录 1. 项目介绍2. 开发环境准备3. 设计应用界面4. 创建Vue实例和数据模型5. 实现记事本功能5.1 添加新记事项5.2 删除记事项5.3 清空所有记事 6. 添加样式7. 功能扩展:显示创建时间8. 功能扩展:记事项搜索9. 完整代码10. Vue知识点解析10.1 数据绑…...
中南大学无人机智能体的全面评估!BEDI:用于评估无人机上具身智能体的综合性基准测试
作者:Mingning Guo, Mengwei Wu, Jiarun He, Shaoxian Li, Haifeng Li, Chao Tao单位:中南大学地球科学与信息物理学院论文标题:BEDI: A Comprehensive Benchmark for Evaluating Embodied Agents on UAVs论文链接:https://arxiv.…...
C++.OpenGL (10/64)基础光照(Basic Lighting)
基础光照(Basic Lighting) 冯氏光照模型(Phong Lighting Model) #mermaid-svg-GLdskXwWINxNGHso {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-GLdskXwWINxNGHso .error-icon{fill:#552222;}#mermaid-svg-GLd…...
短视频矩阵系统文案创作功能开发实践,定制化开发
在短视频行业迅猛发展的当下,企业和个人创作者为了扩大影响力、提升传播效果,纷纷采用短视频矩阵运营策略,同时管理多个平台、多个账号的内容发布。然而,频繁的文案创作需求让运营者疲于应对,如何高效产出高质量文案成…...
CVE-2020-17519源码分析与漏洞复现(Flink 任意文件读取)
漏洞概览 漏洞名称:Apache Flink REST API 任意文件读取漏洞CVE编号:CVE-2020-17519CVSS评分:7.5影响版本:Apache Flink 1.11.0、1.11.1、1.11.2修复版本:≥ 1.11.3 或 ≥ 1.12.0漏洞类型:路径遍历&#x…...
STM32---外部32.768K晶振(LSE)无法起振问题
晶振是否起振主要就检查两个1、晶振与MCU是否兼容;2、晶振的负载电容是否匹配 目录 一、判断晶振与MCU是否兼容 二、判断负载电容是否匹配 1. 晶振负载电容(CL)与匹配电容(CL1、CL2)的关系 2. 如何选择 CL1 和 CL…...
华为OD最新机试真题-数组组成的最小数字-OD统一考试(B卷)
题目描述 给定一个整型数组,请从该数组中选择3个元素 组成最小数字并输出 (如果数组长度小于3,则选择数组中所有元素来组成最小数字)。 输入描述 行用半角逗号分割的字符串记录的整型数组,0<数组长度<= 100,0<整数的取值范围<= 10000。 输出描述 由3个元素组成…...
【Veristand】Veristand环境安装教程-Linux RT / Windows
首先声明,此教程是针对Simulink编译模型并导入Veristand中编写的,同时需要注意的是老用户编译可能用的是Veristand Model Framework,那个是历史版本,且NI不会再维护,新版本编译支持为VeriStand Model Generation Suppo…...
沙箱虚拟化技术虚拟机容器之间的关系详解
问题 沙箱、虚拟化、容器三者分开一一介绍的话我知道他们各自都是什么东西,但是如果把三者放在一起,它们之间到底什么关系?又有什么联系呢?我不是很明白!!! 就比如说: 沙箱&#…...
