mysql 分组函数,分组查询

#1.分组函数
功能:用作统计使用,又称聚合函数,统计函数,组函数
分类: sum :求和,avg 平均值,max最大值,min最小值,count计算个数
特点:
sum, avg 一般用于处理数值型
max ,min ,count 可以处理任何类型
是否忽略Null
count:
MYISAM 存储引擎下,COUNT() 的效率高
INNODB 存储引擎下,COUNT(
)和 COUNT(1)的效率差不多,比COUNT(字段)要高一些

1.简单的使用

SELECT SUM(salary) FROM employees;
SELECT AVG(salary) FROM employees;
SELECT MIN(salary) FROM employees;
SELECT MAX(salary) FROM employees;
SELECT COMMIT(salary) FROM employees;
SELECT SUM(salary) 和,AVG(salary) 平均,MAX(salary) 最大,MIN(salary) 最小 FROM employees;
#1.count 函数的详细介绍
//count:
//MYISAM 存储引擎下,COUNT() 的效率高
//INNODB 存储引擎下,COUNT()和 COUNT(1)的效率差不多,比COUNT(字段)要高一些
SELECT COUNT(salary) FROM employees;
SELECT COUNT(*) FROM employees;
SELECT COUNT(1) FROM employees;
#和分组函数一同查询的字段有限制
#案例1.查询公司员工的工资最大值,最小值,平均值,总和
SELECT MAX(salary) mx_sal,MIN(salary) mi_sal,AVG(salary) ag_sal,SUM(salary) sm_sal FROM employees;
#案列2. 查询员工表中的最大入职时间和最小入职时间的相差天数
SELECT DATEDIFF(MAX(hiredate),MIN(hiredate)) DIFFRENCE FROM employees;
#案例3 查询部门编号为90的员工个数
SELECT COUNT(*) FROM employees WHERE department_id =90;

分组数据,分组查询
#GROUP BY 字句语法
可以使用GROUP BY子句将表中的数据分成若干组
语法: SELECT 分组函数,列(要求出现在grounp by的后面)
FROM 表
【where 筛选条件】
grounp by 分组的列表
【order by 子句】
ps: 查询列表必须特殊,要求是分组函数和group by后出现的字段

#案列1:查询每个部门的平均工资
SELECT MAX(salary),job_id
FROM employees
GROUP BY job_id;
#案列2: 查询每个工种的最高工资
SELECT MAX(salary),job_id
FROM employees;
GROUP BY job_id;#案列3 查询每个位置上的部门个数
SELECT COUNT(*),location_id
FROM departments
GROUP BY location_id;
#添筛选条件
#案例1:查询邮箱中包含a字符的,每个部门的平均工资
SELECT AVG(salary),department_id
FROM employees;
WHERE email LIKE '%a%'
GROUP BY department_id;
#案例2 查寻有奖金的每个领导手下员工的最高工资
SELECT MAX(salary),manager_id
FROM employees;
WHERE commission_pct IS NOT NULL
GROUP BY manager_id;
#案例3 查询那个部门的员工个数>2#1.查询每个部门的员工个数
SELECT COUNT(*),department_id
FROM employees;
GROUP BY department_id;
#2.根据1的结果进行帅选,查询那个部门的员工个数>2
SELECT COUNT(*),department_id
FROM employees;
GROUP BY department_id
HAVING COUNT(*)>2;
#案例4;查询每个工种有奖金的员工的最高工资>12000的工种编号和最高工资
# 1.查询每个工种有奖金的员工的最高工资
SELECT MAX(salary),job_id
FROM employees
WHERE commission_pct IS NOT NULL
GROUP BY job_id;
# 2.根据1结果继续帅选,最高工资>12000
SELECT MAX(salary),job_id
FROM employees
WHERE commission_pct IS NOT NULL
GROUP BY job_id
HAVING MAX(salary)>12000;

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

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

相关文章

metartc5_jz源码阅读-udp->receive

之前在metartc5_jz源码阅读-yang_run_rtcudp_thread-CSDN博客中说到: //调用udp的receive方法将读取的buffer和udp->user传入。 if (udp->receive) udp->receive(buffer, len, udp->user); 这个函数在以下代码中已经设置执行函数: sessio…

RV1126边缘计算AI盒子,支持4-6路1080p视频,2T 算力

1 产品概述 信迈推出基于瑞芯微Rockchip RV1126架构的AI边缘计算主板,RV1126芯片是四核ARM Cortex-A7,1.5GHz, RSIC-V 200MHz CPU ,NPU2.0Tops。AI边缘计算主板外围接口丰富,拥有超强扩展性,可广泛应用在智慧安防、工…

docker一键安装

1.把docker_compose_install文件夹放在任意路径; 2.chmod -R 777 install.sh 3.执行./install.sh 兼容:CentOS7.6、麒麟V10服务器版、统信UOS等操作系统。 下载地址(本人上传,免积分下载):https://downlo…

移动安全-keytool

1 需求 需求1:获取应用签名的CN、OU、O字段 keytool -printcert -jarfile C:\Contacts_MFV.apk | findstr CN 需求2:获取应用签名的MD5 2 语法 C:\Program Files\java\jdk-19.0.1\bin>keytool 密钥和证书管理工具命令:-certreq 生成证…

Salesforce Reports Dashboards in Lightning

Lightning UI下如何快速实现业务的报表及图表的需求,是很多新上手Salesforce管理员的要快速把握的点,因为系统上线的目的之一就是为了实现管理的需求。 Salesforce Report: Report有哪几种类型?如何选择合适的Report Type&#…

JS逆向之加密参数定位

文章目录 前言加密参数的处理步骤加密参数的定位方法搜索断点XHR断点DOM断点EVENT断点 hook 前言 当我们对网络请求进行抓包分析之后,需要用开发者工具对加密参数进行全局搜索。当搜索不到加密参数的时候,应该采取什么解决方法去定位。 还有一个应用场…

【动态规划】C++ 算法458:可怜的小猪

作者推荐 视频算法专题 涉及知识点 动态规划 数学 力扣458:可怜的小猪 有 buckets 桶液体,其中 正好有一桶 含有毒药,其余装的都是水。它们从外观看起来都一样。为了弄清楚哪只水桶含有毒药,你可以喂一些猪喝,通过观察猪是否…

2022年面经记录(base杭州)

duandian科技(笔试未通过) 笔试题:leetCode热题第20题有效的括号 面后感:没怎么刷算法题,js 基础不扎实 laiweilai(三面未通过) 一面:笔试题 写一个函数,获取url中的指定…

Linux 系统面试题

Linux 系统面试题 1. 什么是 Linux? Linux 是一个开源的类 UNIX 操作系统内核,最初由 Linus Torvalds 在1991年创建。 2. Linux 的优势是什么? 开源、免费强大的安全性多用户、多任务支持稳定性和性能良好的网络功能可定制性和灵活性 3.…

TDengine 签约西电电力

近年来,随着云计算和物联网技术的迅猛发展,传统电力行业正朝着数字化、信息化和智能化的大趋势迈进。在传统业务基础上,电力行业构建了信息网络、通信网络和能源网络,致力于实现发电、输电、变电、配电和用电的实时智能联动。在这…

React16源码: React中的不同的expirationTime的源码实现

不同的 expirationTime 1 )概述 在React中不仅仅有异步任务大部分情况下都是同步的任务,所以会有不同 expirationTime 的存在 2 )种类 A. Sync 模式,优先级最高 任务创建完成之后,立马更新到真正的dom里面是一个创建…

13.若依代码自动生成功能详解

文章目录 1.代码自动生成功能2.功能的使用3. 代码的导出和使用 1.代码自动生成功能 基于若依的目录结构,若依本身提供了代码生成功能,可以根据数据库表的内容,生成一些基本的CRUD的前后端的功能。本文将生成过程中的一些注意事项&#xff0c…

html 原生网页使用ElementPlus 日期控件el-date-picker换成中文

项目: 原生的html,加jQuery使用不习惯,新html页面导入vue3,element plus做界面,现在需要把日历上英文切成中文。 最终效果: 导入能让element plus日历变成中文脚本: elementplus, vue3对应的js都可以通过创建一个vu…

git 上传小知识

git init git add . git commit -m "存储到本地仓库中去" (将内容存储到本地master分支) git push -u origin master “上传到远程master分支上” 如若要写login登录页,假设此时是在新分支上写的 git checkout -b login &…

【css技巧】文本超出两行显示省略号

ChatGPT4.0国内站点:海鲸AI 你可以使用CSS的-webkit-line-clamp属性来实现文本超出两行显示省略号的效果。示例代码如下: .text-container {display: -webkit-box;-webkit-box-orient: vertical;overflow: hidden;text-overflow: ellipsis;-webkit-line…

SpringCloud技术栈——技术词汇

目录 SpringCloud介绍Spring Cloud技术栈 Spring Cloud相关专业技术词汇基本的Spring Cloud项目模板 SpringCloud介绍 Spring Cloud是一个基于Spring Boot的微服务开发框架,它提供了一系列的开发工具和功能,帮助开发人员快速构建分布式应用程序。Spring…

1768. 交替合并字符串

1768. 交替合并字符串 给你两个字符串 word1 和 word2 。请你从 word1 开始,通过交替添加字母来合并字符串。如果一个字符串比另一个字符串长,就将多出来的字母追加到合并后字符串的末尾。 返回 合并后的字符串 。 示例 1: 输入&#xff…

2023年12月 C/C++(一级)真题解析#中国电子学会#全国青少年软件编程等级考试

C/C++编程(1~8级)全部真题・点这里 第1题:数的输入和输出 输入一个整数和双精度浮点数,先将浮点数保留2位小数输出,然后输出整数。 时间限制:1000 内存限制:65536 输入 一行两个数,分别为整数N(不超过整型范围),双精度浮点数F,以一个空格分开。 输出 一行两个数,分…

CNCF之CoreDNS

目前我们学习云原生技术,就不得不去了解CNCF,即Cloud Native Computing Foundation,云原生计算基金会,它的宣言或理念是: The Cloud Native Computing Foundation (CNCF) hosts critical components of the global tec…

前端系列:ES6-ES12新语法

文章目录 ECMAScript系列:简介ECMAScript系列:ES6新特性let 关键字const 关键字变量的解构赋值模板字符串简化对象写法箭头函数参数默认值rest 参数spread扩展运算符Symbol迭代器生成器PromiseSetMapclass类数值扩展对象扩展模块化 ECMAScript系列&#…