【MYSQL】聚合查询、分组查询、联合查询

目录
  • 一、聚合查询
    • [1.1 聚合函数](#1.1 聚合函数)
      • [1.1.1 count()](#1.1.1 count())
      • [1.1.2 sum()](#1.1.2 sum())
      • [1.1.3 avg()](#1.1.3 avg())
      • [1.1.4 max()和min()](#1.1.4 max()和min())
      • [1.1.5 总结](#1.1.5 总结)
  • 二、分组查询
    • [2.1 group by 子句](#2.1 group by 子句)
    • [2.2 having 子句](#2.2 having 子句)
  • 三、联合查询
    • [3.1 笛卡尔积](#3.1 笛卡尔积)
    • [3.2 内连接](#3.2 内连接)
    • [3.3 外连接](#3.3 外连接)
    • [3.4 自连接](#3.4 自连接)
    • [3.5 子查询](#3.5 子查询)
      • [3.5.1 单行子查询](#3.5.1 单行子查询)
      • [3.5.2 多行子查询](#3.5.2 多行子查询)
      • [3.5.3 from子句使用子查询](#3.5.3 from子句使用子查询)
  • 四、合并查询

一、聚合查询

聚合查询就是针对表中行与行之间的查询。

1.1 聚合函数

1.1.1 count()

count(列名):查询当前列下面有多少条数据。

复制代码
select count(*) from 表名;#查询当前表有多少行
select count(列名) from 表名;#查询该列有多少行
  • count(1),里面加个数字常量也可以达到count(*)的效果,推荐写count(*)。
  • 使用count(列名)查询到null时不算入行数。
1.1.2 sum()

把查询到的结果相加。

复制代码
select sum(列名) from 表名;#将该列所有值相加
  • 必须是数字,不是数字会报警告没结果。
  • 使用该函数会将null不计算,不会出现加上null和为null的结果。
1.1.3 avg()

求查询到结果的平均值。

复制代码
select avg(列名/表达式) from 表名;#将该列所有值的平均数
  • 必须是数字,不是数字会报警告没结果。
  • 使用该函数会将null那行不计算,比如1,2,null平均值为(1 + 2)/ 2 = 1.5000。
1.1.4 max()和min()

分别返回查到的最大值和最小值。

复制代码
select max(列名) from 表名;#返回该列最大值
select min(列名) from 表名;#返回该列最小值
  • 必须是数字,不是数字会报警告没结果。
  • null不参与。
1.1.5 总结

函数

说明

count (列名)

返回查询到的数据的 数量

sum(列名)

返回查询到的数据的 总和,不是数字没有意义

avg(列名)

返回查询到的数据的 平均值,不是数字没有意义

max(列名)

返回查询到的数据的 最大值,不是数字没有意义

min(列名)

返回查询到的数据的 最小值,不是数字没有意义

二、分组查询

2.1 group by 子句

查询(select) 中使用 group by子句可以对指定列进行分组查询。

功能就是将查询到的结果中 group by 子句后的列完全相同的合并在一起。

复制代码
select 列名.... from 表名 group by 列名1, 列名2;

group by 子句后也可以跟 order by子句排序。

2.2 having 子句

group by 子句进行分组以后,需要对分组结果再进行条件过滤时,不能使用 where语句,而需要用having。

因为分组结果在结果集中是临时表,不是真是的数据,where处理的事是真实数据。

复制代码
select 列名.... from 表名 group by 列名1, 列名2 having 条件;

三、联合查询

联合查询就是将多张表联合起来查询,将需要的信息一起取出来。

3.1 笛卡尔积

笛卡尔积就是将表中每行与其他表的行进行全排列。

复制代码
select .... from 表1,表2;

例如:

  • 当使用笛卡尔积的表含有主外键查询时,因为是全排列,必然会产生无效数据,我们就可以使用条件查询,但是必须要使用 表名.列名。

  • 通过指定列查询精简结果集时也需要使用 表名.列名。

  • 可以通过给表名起别名来精简SQL语句。

3.2 内连接

两种写法:

复制代码
select 列名 from 表1 as 别名1,表2 as 别名2 where 条件 and 其他条件;

select 列名 from 表1 as 别名1 join 表2 as 别名 on 条件 and 其他条件; 

3.3 外连接

外连接分为左外连接和右外连接。

如果联合查询,join 左侧的表完全显示我们就说是左外连接;

join右侧的表完全显示我们就说是右外连接。

复制代码
select 列名 from 表1 as 别名1 right join 表2 as 别名2 on 条件;#右外连接,表2全显示

select 列名 from 表1 as 别名1 left join 表2 as 别名2 on 条件;#左外连接,表1全显示

3.4 自连接

自连接是指在同一张表连接自身进行查询。

但是必须要对表进行起不同的别名。

复制代码
select 列名 from 表名 as 别名1,表名 as 别名2 where 条件 and 其它条件;

select 列名 from 表名 as 别名1 join 表名 as 别名2 on 条件 and 其它条件;

3.5 子查询

子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询。

复制代码
select 列名 from 表名 where 列 = (select语句 );#例子
3.5.1 单行子查询

作为条件的子查询语句返回值只有一行数据。

3.5.2 多行子查询

作为条件的子查询语句返回值有多行行数据。

  • 可以使用in来处理:

  • 可以使用多列包含:

    将where条件括号中与返回值一一进行比较

  • 使用[not] exists关键字

    select 列名 from 表名 where exists (select语句);

后面查询语句返回结果集为空就不执行前面的查询语句,反之不为空执行。

3.5.3 from子句使用子查询

在from子句中使用子查询:子查询语句出现在from子句中。

把一个子查询当做一个临时表使用。

四、合并查询

为了合并多个select的执行结果,可以使用集合操作符 union,union all。

使用union 和union all时,前后查询的结果集中,字段需要一致。

  • union操作符用于取得两个结果集的并集。当使用该操作符时,
    会自动去掉结果集中的重复行。
  • union all 操作符用于取得两个结果集的并集。当使用该操作符时,不会去掉结果集中的重复行。
相关推荐
kngines34 分钟前
【PostgreSQL数据分析实战:从数据清洗到可视化全流程】电商数据分析案例-9.1 业务场景与数据准备
数据库·postgresql·数据分析·数据质量评估
qq_3660862240 分钟前
sql serve 多表联合查询,根据一个表字段值动态改变查询条件
数据库·sql
odng1 小时前
Redis如何实现分布式锁
数据库·redis·分布式
长流小哥2 小时前
MySQL C API高效编程:C语言实现数据库操作的深入解析
数据库·c++·mysql
JhonKI2 小时前
【MySQL】存储引擎 - MEMORY详解
数据库·mysql
pqq的迷弟2 小时前
redis多路复用IO模型 以及 6.0引入的多线程模型
数据库·redis·php
larance2 小时前
Django rest_framework 信号机制生成并使用token
数据库·django·sqlite
didiplus3 小时前
MySQL 8.0 OCP(1Z0-908)英文题库(11-20)
数据库·mysql·adb·认证·ocp
等雨季4 小时前
电商双11美妆数据分析(二)
数据库
朝新_4 小时前
【MySQL】第二弹——MySQL表的增删改查(CURD))
mysql