MySQL进阶-增删查改(全网最详细sql教学)-2

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: MySQL进阶-增删查改(全网最详细sql教学)

MySQL进阶-增删查改(全网最详细sql教学)-1

https://developer.aliyun.com/article/1517119


聚合查询

在查询的过程中, 对表的行与行之间进行一定的运算, 这种查询需要依赖SQL提供的库函数. 常见的有统计总数, 计算平均值等操作, 如下表:


函数

说明

COUNT([DISTINCT] exam)

返回查询到的数据的数量

SUM([DISTINCT] exam)

返回查询到的数据的总和

AVG([DISTINCT] exam)

返回查询到的数据的平均值

MAX([DISTINCT] exam)

返回查询到的数据的最大值

MIN([DISTINCT] exam)

返回查询到的数据的最小值


COUNT

新建一张学生表 :

student (id , name)


create table student(id int, name varchar(20));


然后向里面插入四个数据如下:

然后使用count, 语句如下:

select count(*) from student;

select count(id) from student;

select count(name) from student;



这个操作可以理解为, 先执行select* 操作去查询所有数据, 然后去计算select* 查询结果有多少行.例如上面的select count(id) 和 select count(*) 操作, 但是如果数据里面遇到的记录为NULL, 那么这一行记录是不会被count计算进去的, 就例如select count(name) .


如果你不想将NULL指定为有效行数, 那么就可以直接使用count来指定列查询, 如果你认为NULL也为有效数据, 那么你可以使用count(*) 来进行查询.


SUM

sum求和只是针对数字列有效, 如果是字符串或者其他类型的列, 将无法计算

例如我们创建这样的一张表:

INSERT INTO exam_result (id,name, chinese, math, english) VALUES

(1,'唐三藏', 67, 98, 56),

(2,'孙悟空', 87.5, 78, 77),

(3,'猪悟能', 88, 98.5, 90),

(4,'曹孟德', 82, 84, 67),

(5,'刘玄德', 55.5, 85, 45),

(6,'孙权', 70, 73, 78.5),

(7,'宋公明', 75, 65, 30)

(8,'鲁班七号', null, null, null);


使用sum函数来对所有记录的chinese 字段进行求和:

select sum(chinese) from exam_result;


说明: 如果里面数据为null, sum会自动跳过结果为null的数据.

如果对name这种非数字类型进行sum操作:

select sum(name) from exam_result;


结果显示:

1 row in set, 8 warnings (0.00 sec)

使用show warnings 来查看警告内容:

show warnings;


Truncated incorrect DOUBLE value : 当前类型向double类型转换失败.

AVG

计算平均数据,计算出来的数据为double类型

还是这个数据表:


对其chinese 的成绩进行AVG计算平均分操作:

select avg(chinese) from exam_result;


也可以搭配表达式使用: 例如求总分的成绩 :

select avg( chinese + math + english) from exam_result;


也可以使用as来对其命名:


select avg( chinese + math + english) as totalAVG from exam_result;

9fa103ad4a115c3183b667548791e3a5_52bfe58025744aad889472ae7ad29976.png

下面max和min的例子同样使用如下表格:

d2f2a3f03ace740bd658cb586acb8419_90ec4aaaf8a54b42ae9bdef065d6608e.png

MAX

查询表中指定列的最大值, 例如查询chinese的最大值:

select max(chinese) from exam_result;


MIN

同MAX, 这里不做过多介绍.

GROUP BY

通常搭配聚合函数,select 语句中使用group by 可以对指定列进行分组查询,


例如这里创建一个员工表,如下:


create table emp (id int, name varchar(20), role varchar(20), salary int);

插入七条记录:


如何求出每个岗位的平均工资?


这个时候就需要使用分组查询了, 也就是group by操作.


使用group by语句, 可以让指定的列里面, 相同的值分到同一个组当中:


要求每个岗位的平均工资, 就需要指定岗位的类型来进行分组

082d7efca1002e00ca5d3917a205340d_23d7d6703124411c99b65ec7d6d25b2e.png


然后对其进行平均工资计算:


select role, avg(salary) from emp group by role;

d7ca5b2db50ef20400383b2c19172fdf_da4e0edbd50448d6bdb56fdb6ead3a5c.png

1.分组前查询

使用where.


例如求每个岗位的平均值, 但是不包括"张三".


select role, avg(salary) from emp where name != "张三" group by role;

0b2bf4fd093cae17d9718756d5531cbd_7e97a88aa44c48e09faf4d299e0f2bc3.png

2.分组后查询

使用having关键字


例如, 求所有岗位的平均薪资, 但是不包括老板:


select role, avg(salary) from emp group by having role != "老板";

5cc77e3aeda4e3e374ff63a67c067625_fe2d14ee807a4cd98eed36b17d36098f.png

3.同时在分组前分组后筛选

使用where在分组前筛选, 同时使用having关键字在分组后筛选.


select role, avg(salary) from emp where name != "张三" group by role having role != "老板";

32ff05e200dbf5be5f3d56b81565be85_c3bc607a59024fd998c2807d92f74b90.png

联合查询

也成为多表查询, 这种多表查询依赖于一个笛卡尔积的前提.

笛卡尔积

定义:设A,B为集合, 用A中元素为第一元素, B中的元素为第二元素, 构成有序数对, 所有这样的有序数对组成的集合称作A和B的笛卡尔积,记作AXB = {| xA ^ y B}.


例如 A = {a, b}, B = {0, 1, 2}.


AXB = {,,,,,<,2>}.


有序数对: 由两个元素x和y按一定的顺序成的二元组成为一个有序对, 记作.


存在两张表:


studentList (studentID, name, class)

classList (classID, className )

fa9078b6911e73e126f9859a8b301f32_5b40d80ff6204220b41728d499908c8b.png

里面存在着如上图的数据


让两张表进行笛卡尔积运行算,形成一张新表如下:


resultList (studentID, name, classID, className);

新的表的数据如图: 班级表里面的数据依次对学生表里面的每一个记录进行组合的一个排列


这份结果表, 就是学生表和班级表的笛卡尔积结果.


笛卡尔积出来的表格有很多数据,但并不是所有的数据都是有效数据, 就比如说上表数据中的记录:

这些记录的左边的班级ID和右边的班级ID不相同, 是没有意义的数据.


当我们去掉这些数据之后, 笛卡尔积的结果表就是两个表合并的结果.


要去掉这些数据, 可以增加where条件语句, 来过滤掉这些没有意义的数据.


MySQL进阶-增删查改(全网最详细sql教学)-3

https://developer.aliyun.com/article/1517152

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
5
分享
相关文章
MySQL进阶突击系列(07) 她气鼓鼓递来一条SQL | 怎么看执行计划、SQL怎么优化?
在日常研发工作当中,系统性能优化,从大的方面来看主要涉及基础平台优化、业务系统性能优化、数据库优化。面对数据库优化,除了DBA在集群性能、服务器调优需要投入精力,我们研发需要负责业务SQL执行优化。当业务数据量达到一定规模后,SQL执行效率可能就会出现瓶颈,影响系统业务响应。掌握如何判断SQL执行慢、以及如何分析SQL执行计划、优化SQL的技能,在工作中解决SQL性能问题显得非常关键。
MySQL原理简介—1.SQL的执行流程
本文介绍了MySQL驱动、数据库连接池及SQL执行流程的关键组件和作用。主要内容包括:MySQL驱动用于建立Java系统与数据库的网络连接;数据库连接池提高多线程并发访问效率;MySQL中的连接池维护多个数据库连接并进行权限验证;网络连接由线程处理,监听请求并读取数据;SQL接口负责执行SQL语句;查询解析器将SQL语句解析为可执行逻辑;查询优化器选择最优查询路径;存储引擎接口负责实际的数据操作;执行器根据优化后的执行计划调用存储引擎接口完成SQL语句的执行。整个流程确保了高效、安全地处理SQL请求。
187 76
MySQL的架构与SQL语句执行过程
MySQL架构分为Server层和存储引擎层,具有高度灵活性和可扩展性。Server层包括连接器、查询缓存(MySQL 8.0已移除)、分析器、优化器和执行器,负责处理SQL语句;存储引擎层负责数据的存储和读取,常见引擎有InnoDB、MyISAM和Memory。SQL执行过程涉及连接、解析、优化、执行和结果返回等步骤,本文详细讲解了一条SQL语句的完整执行过程。
23 3
基于SQL Server / MySQL进行百万条数据过滤优化方案
对百万级别数据进行高效过滤查询,需要综合使用索引、查询优化、表分区、统计信息和视图等技术手段。通过合理的数据库设计和查询优化,可以显著提升查询性能,确保系统的高效稳定运行。
21 2
【YashanDB 知识库】如何将 mysql 含有 group by 的 SQL 转换成崖山支持的 SQL
在崖山数据库中执行某些 SQL 语句时出现报错(YAS-04316 not a single-group group function),而这些语句在 MySQL 中能成功执行。原因是崖山遵循 SQL-92 标准,不允许选择列表中包含未在 GROUP BY 子句中指定的非聚合列,而 MySQL 默认允许这种操作。解决办法包括:使用聚合函数处理非聚合列或拆分查询为两层,先进行 GROUP BY 再排序。总结来说,SQL-92 更严格,确保数据一致性,MySQL 在 5.7 及以上版本也默认遵循此标准。
MySQL原理简介—10.SQL语句和执行计划
本文介绍了MySQL执行计划的相关概念及其优化方法。首先解释了什么是执行计划,它是SQL语句在查询时如何检索、筛选和排序数据的过程。接着详细描述了执行计划中常见的访问类型,如const、ref、range、index和all等,并分析了它们的性能特点。文中还探讨了多表关联查询的原理及优化策略,包括驱动表和被驱动表的选择。此外,文章讨论了全表扫描和索引的成本计算方法,以及MySQL如何通过成本估算选择最优执行计划。最后,介绍了explain命令的各个参数含义,帮助理解查询优化器的工作机制。通过这些内容,读者可以更好地理解和优化SQL查询性能。
【MySQL基础篇】全面学习总结SQL语法、DataGrip安装教程
本文详细介绍了MySQL中的SQL语法,包括数据定义(DDL)、数据操作(DML)、数据查询(DQL)和数据控制(DCL)四个主要部分。内容涵盖了创建、修改和删除数据库、表以及表字段的操作,以及通过图形化工具DataGrip进行数据库管理和查询。此外,还讲解了数据的增、删、改、查操作,以及查询语句的条件、聚合函数、分组、排序和分页等知识点。
【MySQL基础篇】全面学习总结SQL语法、DataGrip安装教程
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
8月前
|
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
197 13
|
8月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
118 9

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等