【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 操作符用于取得两个结果集的并集。当使用该操作符时,不会去掉结果集中的重复行。
相关推荐
不剪发的Tony老师1 小时前
Mathesar:一款基于PostgreSQL的在线电子表格
数据库·postgresql·电子表格
万邦科技Lafite4 小时前
京东按图搜索京东商品(拍立淘) API (.jd.item_search_img)快速抓取数据
开发语言·前端·数据库·python·电商开放平台·京东开放平台
金仓拾光集5 小时前
__金仓数据库平替MongoDB实战:从多模兼容到高可用落地__
数据库·mongodb·数据库平替用金仓·金仓数据库
北邮-吴怀玉5 小时前
6.1.2.2 大数据方法论与实践指南-离线任务SQL 任务开发规范
大数据·数据库·sql
流烟默5 小时前
MongoDB索引创建语法分析
数据库·mongodb
金仓拾光集5 小时前
__国产化转型实战:制造业供应链物流系统从MongoDB至金仓数据库迁移全指南__
数据库·mongodb·数据库平替用金仓·金仓数据库
初学者_xuan5 小时前
零基础新手小白快速了解掌握服务集群与自动化运维(十五)Redis模块-Redis数据库基础
运维·数据库·自动化
小马哥编程5 小时前
【软考架构】案例分析:MongoDB 如何存储非结构化数据以及其矢量化存储的优点。
数据库·mongodb·架构
默 语6 小时前
MySQL中的数据去重,该用DISTINCT还是GROUP BY?
java·数据库·mysql·distinct·group by·1024程序员节·数据去重
爱隐身的官人6 小时前
Windows配置解压版MySQL5(免安装)
windows·mysql