搜索
首页数据库mysql教程MySQL聚合查询与联合查询操作的示例分析

一. 聚合查询

1.聚合函数(count,sum,avg...)

常见的统计总数、计算平局值等操作,可以使用聚合函数来实现,常见的聚合函数有:

MySQL聚合查询与联合查询操作的示例分析

MySQL聚合查询与联合查询操作的示例分析

MySQL聚合查询与联合查询操作的示例分析

MySQL聚合查询与联合查询操作的示例分析

  • 注意最后面都是可以加上where,order by这些语句的,这些聚合函数会根据这些语句的结果集来进行查询

  • 后面最好不要加上limit,因为MySQL的limit和别的数据库的limit不一样

  • 有使用统计列的聚合函数的时候,避免再写上其他列,不然会出现这种无意义显示第一列的情况

MySQL聚合查询与联合查询操作的示例分析

注意点:

1.count:可以使用count(*),count(0),count(1)这样,说白了实际上和select 1 from整个表是一样的道理,这个count里面的0,1只是作为参数传入而已,先select 1,然后再统计count的值

MySQL聚合查询与联合查询操作的示例分析

MySQL聚合查询与联合查询操作的示例分析

MySQL聚合查询与联合查询操作的示例分析

2.sum,max,min,avg都不可以传入*,必须传入字段或者表达式使用

3.avg可以和sum结合起来用,聚合函数都可以多个一起用

2.GROUP BY子句

使用 GROUP BY 子句可以对特定列进行分组查询。需要满足:使用 GROUP BY 进行分组查询时,SELECT 指定的字段必须是“分组依据字段”,其他字段若想出现在SELECT 中则必须包含在聚合函数中。

  • Select后面的聚合函数是等Group by执行完分组以后才进行的

  • Group by语句的实质就是分组,常配合聚合查询使用

语法:

MySQL聚合查询与联合查询操作的示例分析

MySQL聚合查询与联合查询操作的示例分析

Select指定的字段必须是group by后面有的,没有的只能出现在聚合函数中,不然会出问题

GROUP BY注意事项

1.Group by语句的实质就是分组,常配合聚合查询使用

2.只要有聚合函数出现,就可能要分组

3.分组操作中,查询允许的是分组字段,聚合函数,其他非分组字段需要保证分组后没有多行(如学生id分组,查询字段可以有学生姓名,因为学生id分组以后,只有一行)

4.分组前过滤条件用where,分组后用having(代码是顺序执行的)

执行顺序:from > on> join > where > group by > with > having >select > distinct > order by > limit

  • 最先从from开始执行,所以别名一般都在from这里命名,你在select命名也可以,不过select较后面执行,命名了前面执行那些地方都用不了。

  • Limit永远在最后执行

5.---select classid,average(score) from student where score>60 group by classid havinng classid<=3

先找出score > 60的行,然后按照classid分组,得到的结果里面,再选出class <=3的行,显示出分数总和(显示出1,2,3各班的分数大于60分的学生的平均分)

6.group by 就是将重复的行合并成一行

7.group by 很多个字段的时候,可能没有合并,但是达到了分组的效果,可以使用聚合函数了。

3.HAVING

GROUP BY 子句进行分组以后,需要对分组结果再进行条件过滤时,不能使用 WHERE 语句,而需要用HAVING。HAVING是在GROUP BY 后面执行的

MySQL聚合查询与联合查询操作的示例分析

二. 联合查询((重点)多表)

1.内连接

语法:

MySQL聚合查询与联合查询操作的示例分析

你可能无法区分第二种方法中连接条件和筛选结果集条件的区别。用哪种都行,还是优先用第一种吧,为了和后面的外连接对应。内连接就相当于是在得到的笛卡尔积上给了连接条件

MySQL聚合查询与联合查询操作的示例分析

这里要是不group by进行分组的话,就会像下面这样只有一行,相当于是把所有学生的所有成绩全部加起来了。由于我们需要的是每个学生的总成绩,因此需要先根据学生ID将其分组。

MySQL聚合查询与联合查询操作的示例分析

2.外连接

外连接分为左外连接和右外连接。左外连接是当进行联合查询时,左侧的表完全显示的情况下的一种连接方式;右外连接是当进行联合查询时,右侧的表完全显示的情况下的一种连接方式。

注意点:

  • 左连接:左表的数据不会依据连接条件(on后面的部分,包括and上去的)过滤而全部显示,其他条件还是可以过滤,比如后面再加上where等条件。

  • 如果右表有数据有不满足连接条件的值,右表数据会显示null,左表全显示

语法:(注意:On后面还能跟上where)

MySQL聚合查询与联合查询操作的示例分析

MySQL聚合查询与联合查询操作的示例分析

同样的查询方法,这次能显示出第8名成绩为空的学生的信息,左表也就是student表中的数据会全部显示出来,不会受到连接条件stu.id = sco.student_id这一连接条件的影响,如果是之前的内连接,就显示不出老外学中文这一学生的信息,因为在sco表中根本就没有老外学中文这一学生的id。

3.自连接

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

使用场景:同一张表,多行进行比较。

注:自连接查询也可以使用join on语句来进行查询。

MySQL聚合查询与联合查询操作的示例分析

4.子查询

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

查询与“不想毕业” 同学的同班同学:(自连接)

MySQL聚合查询与联合查询操作的示例分析

多行子查询:返回多行记录的子查询(用的多)

案例:查询“语文”或“英文”课程的成绩信息:(内连接)

MySQL聚合查询与联合查询操作的示例分析

MySQL聚合查询与联合查询操作的示例分析

这里的group by没有起到合并的作用,但是起到了分组的作用

MySQL聚合查询与联合查询操作的示例分析

5.合并查询

在实际应用中,为了合并多个select的执行结果,可以使用集合操作符 union,union all。使用UNION和UNION ALL时,前后查询的结果集中,字段需要一致

**有些情况下,多张表之间没法关联,但是要查询一样字段的数据

**union的效率比or高

  • union

该操作符用于取得两个结果集的并集。该操作符会自动消除结果集中的重复行,当数据内容完全相同时会自动去重。

案例:查询id小于3,或者名字为“英文”的课程:

MySQL聚合查询与联合查询操作的示例分析

  • union all

该操作符用于取得两个结果集的并集。当使用该操作符时,不会去掉结果集中的重复行。(取到的数据完全一样的时候,都会显示出来,不会进行去重)

案例:查询id小于3,或者名字为“Java”的课程

MySQL聚合查询与联合查询操作的示例分析

以上是MySQL聚合查询与联合查询操作的示例分析的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:亿速云。如有侵权,请联系admin@php.cn删除
MySQL中有哪些不同的存储引擎?MySQL中有哪些不同的存储引擎?Apr 26, 2025 am 12:27 AM

mysqloffersvariousStorageengines,每个suitedfordferentusecases:1)InnodBisidealForapplicationsNeedingingAcidComplianCeanDhighConcurncurnency,supportingtransactionsancions and foreignkeys.2)myisamisbestforread-Heavy-Heavywyworks,lackingtransactionsactionsacupport.3)记忆

MySQL中有哪些常见的安全漏洞?MySQL中有哪些常见的安全漏洞?Apr 26, 2025 am 12:27 AM

MySQL中常见的安全漏洞包括SQL注入、弱密码、权限配置不当和未更新的软件。1.SQL注入可以通过使用预处理语句防止。2.弱密码可以通过强制使用强密码策略避免。3.权限配置不当可以通过定期审查和调整用户权限解决。4.未更新的软件可以通过定期检查和更新MySQL版本来修补。

您如何确定MySQL中的慢速查询?您如何确定MySQL中的慢速查询?Apr 26, 2025 am 12:15 AM

在MySQL中识别慢查询可以通过启用慢查询日志并设置阈值来实现。1.启用慢查询日志并设置阈值。2.查看和分析慢查询日志文件,使用工具如mysqldumpslow或pt-query-digest进行深入分析。3.优化慢查询可以通过索引优化、查询重写和避免使用SELECT*来实现。

如何监视MySQL Server的健康和性能?如何监视MySQL Server的健康和性能?Apr 26, 2025 am 12:15 AM

要监控MySQL服务器的健康和性能,应关注系统健康、性能指标和查询执行。1)监控系统健康:使用top、htop或SHOWGLOBALSTATUS命令查看CPU、内存、磁盘I/O和网络活动。2)追踪性能指标:监控查询每秒数、平均查询时间和缓存命中率等关键指标。3)确保查询执行优化:启用慢查询日志,记录并优化执行时间超过设定阈值的查询。

比较和对比Mysql和Mariadb。比较和对比Mysql和Mariadb。Apr 26, 2025 am 12:08 AM

MySQL和MariaDB的主要区别在于性能、功能和许可证:1.MySQL由Oracle开发,MariaDB是其分支。2.MariaDB在高负载环境中性能可能更好。3.MariaDB提供了更多的存储引擎和功能。4.MySQL采用双重许可证,MariaDB完全开源。选择时应考虑现有基础设施、性能需求、功能需求和许可证成本。

MySQL的许可与其他数据库系统相比如何?MySQL的许可与其他数据库系统相比如何?Apr 25, 2025 am 12:26 AM

MySQL使用的是GPL许可证。1)GPL许可证允许自由使用、修改和分发MySQL,但修改后的分发需遵循GPL。2)商业许可证可避免公开修改,适合需要保密的商业应用。

您什么时候选择InnoDB而不是Myisam,反之亦然?您什么时候选择InnoDB而不是Myisam,反之亦然?Apr 25, 2025 am 12:22 AM

选择InnoDB而不是MyISAM的情况包括:1)需要事务支持,2)高并发环境,3)需要高数据一致性;反之,选择MyISAM的情况包括:1)主要是读操作,2)不需要事务支持。InnoDB适合需要高数据一致性和事务处理的应用,如电商平台,而MyISAM适合读密集型且无需事务的应用,如博客系统。

在MySQL中解释外键的目的。在MySQL中解释外键的目的。Apr 25, 2025 am 12:17 AM

在MySQL中,外键的作用是建立表与表之间的关系,确保数据的一致性和完整性。外键通过引用完整性检查和级联操作维护数据的有效性,使用时需注意性能优化和避免常见错误。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器