服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

香港云服务器
服务器之家 - 数据库 - Mysql - MySQL必备基础之分组函数 聚合函数 分组查询详解

MySQL必备基础之分组函数 聚合函数 分组查询详解

2021-11-22 18:12叶绿体不忘呼吸 Mysql

这篇文章主要介绍了MySQL分组函数、聚合函数、分组查询,结合实例形式分析了MySQL查询分组函数以及查询聚合函数相关使用技巧,需要的朋友可以参考下

一、简单使用

sum:求和(一般用于处理数值型)
avg:平均(一般用于处理数值型)
max:最大(也可以用于处理字符串和日期)
min:最小(也可以用于处理字符串和日期)
count:数量(统计非空值的数据个数)

以上分组函数都忽略空null值的数据

?
1
2
select sum(salary) as 和,avg(salary) as 平均,max(salary) as 最大,min(salary) as 最小,count(salary) as 数量
from employees;

MySQL必备基础之分组函数 聚合函数 分组查询详解

二、搭配distinct去重

(以上函数均可)

?
1
2
select sum(distinct salary) as 和,avg(distinct salary) as 平均,count( distinct salary) as 去重数量,count(salary) as 不去重数量
from employees;

MySQL必备基础之分组函数 聚合函数 分组查询详解

三、count()详细介绍

?
1
2
3
#相当于统计行数方式一
select count(*)
from employees;
?
1
2
3
#相当于统计行数方式二,其中1可以用其他常量或字段替换
select count(1)
from employees;

效率问题:
myisam存储引擎下,count(*)的效率高
innodb存储引擎下,count(*)count(1)的效率差不多,比count(字段)

因此一般用count(*)统计行数

四、分组查询

?
1
2
3
4
5
6
#其中[]内为可选
select 分组函数,列表(要求出现在 group by 的后面)
from
[where 筛选条件]
group by 分组列表
[order by 子句]

示例:

?
1
2
3
4
#查询每个工种的最高工资
select max(salary) as 最高工资,job_id
from employees
group by job_id;

MySQL必备基础之分组函数 聚合函数 分组查询详解

?
1
2
3
4
5
#查询每个部门中,邮箱包含a的员工的平均工资(分组前的筛选)
select avg(salary) as 平均工资,department_id
from employees
where email like '%a%'
group by department_id;

MySQL必备基础之分组函数 聚合函数 分组查询详解

?
1
2
3
4
5
6
#查询部门员工数量大于2的部门的员工数量(分组后的筛选)
#使用having
select count(*) as 员工数量,department_id
from employees
group by department_id
having count(*)>2;

MySQL必备基础之分组函数 聚合函数 分组查询详解

MySQL必备基础之分组函数 聚合函数 分组查询详解

?
1
2
3
4
#按照多字段
select count(*) as 员工数量,job_id,department_id
from employees
group by job_id,department_id;

MySQL必备基础之分组函数 聚合函数 分组查询详解

?
1
2
3
4
5
6
7
#完整结构
select avg(salary) as 平均工资,department_id
from employees
where department_id is not null
group by department_id
having avg(salary)>9000
order by avg(salary) desc;

MySQL必备基础之分组函数 聚合函数 分组查询详解

到此这篇关于mysql必备基础之分组函数 聚合函数 分组查询详解的文章就介绍到这了,更多相关mysql 分组函数 内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/m0_46653805/article/details/120731863

延伸 · 阅读

精彩推荐
  • Mysqlmysql 不能插入中文问题

    mysql 不能插入中文问题

    当向mysql5.5插入中文时,会出现类似错误 ERROR 1366 (HY000): Incorrect string value: '\xD6\xD0\xCE\xC4' for column ...

    MYSQL教程网5722019-11-25
  • Mysql详解MySQL中的分组查询与连接查询语句

    详解MySQL中的分组查询与连接查询语句

    这篇文章主要介绍了MySQL中的分组查询与连接查询语句,同时还介绍了一些统计函数的用法,需要的朋友可以参考下 ...

    GALAXY_ZMY5442020-06-03
  • MysqlMySQL 数据备份与还原的示例代码

    MySQL 数据备份与还原的示例代码

    这篇文章主要介绍了MySQL 数据备份与还原的相关知识,本文通过示例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...

    逆心2972019-06-23
  • Mysql解决MySQl查询不区分大小写的方法讲解

    解决MySQl查询不区分大小写的方法讲解

    今天小编就为大家分享一篇关于解决MySQl查询不区分大小写的方法讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起...

    Veir_dev5592019-06-25
  • Mysql浅谈mysql 树形结构表设计与优化

    浅谈mysql 树形结构表设计与优化

    在诸多的管理类,办公类等系统中,树形结构展示随处可见,本文主要介绍了mysql 树形结构表设计与优化,具有一定的参考价值,感兴趣的小伙伴们可以参...

    小码农叔叔5242021-11-16
  • MysqlMySQL数据库varchar的限制规则说明

    MySQL数据库varchar的限制规则说明

    本文我们主要介绍了MySQL数据库中varchar的限制规则,并以一个实际的例子对限制规则进行了说明,希望能够对您有所帮助。 ...

    mysql技术网4192019-11-23
  • MysqlMySQL锁的知识点总结

    MySQL锁的知识点总结

    在本篇文章里小编给大家整理了关于MySQL锁的知识点总结以及实例内容,需要的朋友们学习下。...

    别人放弃我坚持吖4362020-12-14
  • MysqlERROR: Error in Log_event::read_log_event()

    ERROR: Error in Log_event::read_log_event()

    ERROR: Error in Log_event::read_log_event(): read error, data_len: 438, event_type: 2 ...

    MYSQL教程网6412020-03-13
838