我是靠谱客的博主 甜蜜电话,最近开发中收集的这篇文章主要介绍MySQL的聚合操作, select语句执行顺序,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

聚合操作

聚合操作指的是在数据查找基础上对数据的进一步整理筛选行为,在认识聚合之前先看一个更完整的sql语句

  • select语句执行顺序
(7)
SELECT
(8)
[DISTINCT] <select_list>
(1)
FROM <left_table>
(3)
<join_type> JOIN <right_table>
(2)
ON <join_condition>
(4)
WHERE <where_condition>
(5)
GROUP BY <group_by_list>
(6)
HAVING <having_condition>
(9)
ORDER BY <order_by_condition>
(10)
LIMIT <limit_number>

聚合函数

方法功能
avg(字段名)该字段的平均值
max(字段名)该字段的最大值
min(字段名)该字段的最小值
sum(字段名)该字段所有记录的和
count(字段名)统计该字段记录的个数

eg1 : 找出表中的最大攻击力的值?

select max(attack) from sanguo;

eg2 : 表中共有多少个英雄?

select count(name) as number from sanguo;

eg3 : 蜀国英雄中攻击值大于200的英雄的数量

select count(*) from sanguo where attack > 200;

注意: 此时select 后只能写聚合函数,无法查找其他字段。

聚合分组

  • group by

给查询的结果进行分组
e.g. : 计算每个国家的平均攻击力

select country,avg(attack) from sanguo
group by country;

e.g. : 对多个字段创建索引,此时多个字段都相同时为一组

select age,sex,count(*) from class1 group by age,sex;

e.g. : 所有国家的男英雄中 英雄数量最多的前2名的 国家名称及英雄数量

select country,count(id) as number from sanguo
where gender='M' group by country
order by number DESC
limit 2;

使用分组时select 后的字段为group by分组的字段和聚合函数,不能包含其他内容。group by也可以同时依照多个字段分组,如group by A,B 此时必须A,B两个字段值均相同才算一组。

聚合筛选

  • having语句

对分组聚合后的结果进行进一步筛选

eg1 : 找出平均攻击力大于105的国家的前2名,显示国家名称和平均攻击力
select country,avg(attack) from sanguo
group by country
having avg(attack)>105
order by avg(attack) DESC
limit 2;

注意

  • having语句通常与group by联合使用。
  • having语句存在弥补了where关键字不能与聚合函数联合使用的不足,where只能操作表中实际存在的字段,having操作的是聚合函数生成的显示列

去重语句

  • distinct语句

不显示字段重复值

eg1 : 表中都有哪些国家
select distinct name,country from sanguo;
eg2 : 计算一共有多少个国家
select count(distinct country) from sanguo;

注意

  • distinct和from之间所有字段都相同才会去重

聚合运算

  • 查询表记录时做数学运算

运算符 : + - * / %

eg1: 查询时显示攻击力翻倍
select name,attack*2 from sanguo;
eg2: 更新蜀国所有英雄攻击力 * 2
update sanguo set attack=attack*2 where country='蜀国';

最后

以上就是甜蜜电话为你收集整理的MySQL的聚合操作, select语句执行顺序的全部内容,希望文章能够帮你解决MySQL的聚合操作, select语句执行顺序所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部