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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 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

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
2月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
|
2月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
2月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
339 11
|
2月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
|
2月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
122 3
|
2月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
3月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
2月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
2月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
2月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
383 7