mysql 分组函数和分组查询使用详解

 更新时间:2024年01月11日 09:43:52   作者:鸥总  
分组函数用作统计使用,又称聚合函数,统计函数,组函数,这篇文章主要介绍了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;

到此这篇关于mysql 分组函数 分组查询的文章就介绍到这了,更多相关mysql 分组函数分组查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • InnoDB中不同SQL语句设置锁的情况详解

    InnoDB中不同SQL语句设置锁的情况详解

    这篇文章主要介绍了InnoDB中不同SQL语句设置锁的情况详解,在Mysql中,锁定读、更新、删除操作通常会对SQL语句处理过程中扫描到的每条索引记录设置记录锁,需要的朋友可以参考下
    2024-01-01
  • MySQL索引之聚集索引介绍

    MySQL索引之聚集索引介绍

    在MySQL中,InnoDB引擎表是(聚集)索引组织表(clustered index organize table),而MyISAM引擎表则是堆组织表(heap organize table)
    2015-12-12
  • 详解MySQL 数据库隔离级别与MVCC

    详解MySQL 数据库隔离级别与MVCC

    这篇文章主要介绍了详解MySQL 数据库隔离级别与MVCC的相关资料,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-03-03
  • MySQL对JSON类型字段数据进行提取和查询的实现

    MySQL对JSON类型字段数据进行提取和查询的实现

    本文主要介绍了MySQL对JSON类型字段数据进行提取和查询的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • Mysql如何查看是否使用到索引

    Mysql如何查看是否使用到索引

    这篇文章主要介绍了Mysql如何查看是否使用到索引问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • mysql日常使用中常见报错大全

    mysql日常使用中常见报错大全

    MySQL初学者新安装好数据库及使用过程中经常遇到以下几类错误,本文给大家详细整理并给出完美解决方案,感兴趣的朋友跟随小编一起看看吧
    2023-03-03
  • MySQL去重该使用distinct还是group by?

    MySQL去重该使用distinct还是group by?

    这篇文章主要介绍了MySQL去重该使用distinct还是group by,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05
  • windows下mysql 5.7.20 安装配置方法图文教程

    windows下mysql 5.7.20 安装配置方法图文教程

    这篇文章主要为大家详细介绍了windows下mysql 5.7.20 安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09
  • MySQL query_cache_type 参数与使用详解

    MySQL query_cache_type 参数与使用详解

    这篇文章主要介绍了MySQL query_cache_type参数介绍,需要的朋友可以参考下
    2021-07-07
  • MySQL 基础常用命令总结

    MySQL 基础常用命令总结

    这篇文章主要介绍了MySQL 的基础常用命令,在执行语句的时候,很多命令都是必须记住的,想具体了解的小伙伴请参考下面文章内容
    2021-09-09

最新评论