MySQL查询进阶——从函数到表连接的使用你还记得吗

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: MySQL查询进阶——从函数到表连接的使用你还记得吗

一、MySQL函数的使用


mysql中内置了很多函数,每个函数都代表一个特定功能


1、单行函数


特点:每行数据都会产生一个对应的结果

表中有多少行,就会有多少行的结果

位置:select之后,from之前 或作为筛选条件

concat(…,列名,…,列名)

用来拼接多列的值


例如:以firstname+lastname的形式显示所有员工的姓名

select concat(first_name,last_name) as 全名 from employees

mod(值1,值2)

求值1和值2的取余结果 ,相当于数学运算中的 %(值1%值2)


标准SQL规范中不存在%取余的写法,所以取余操作应该使用mod()

例如:select mod(10,3) from dual

注: dual为虚拟表,作用为使当前SQL符合语法规范,不写时会做自动填充

length(列名|数据)

获取长度


查询所有firstname长度>6的员工信息

select * from employees where length(first_name)>6

now() | sysdate()

获取系统当前时间


select now()

select SYSDATE()

select now() from dual


2、多行函数(组函数)


以组为单位获取结果,一组得到一个结果

如果未手动进行分组,则默认整张表为一组

sum(列名)

求某一列的总和

avg(列名)

求某一列的平均值

max(列名)

求某一列的最大值

min(列名)

求某一列的最小值

count(列名)

求某一列值的个数(非空)

示例:


-- 组函数操作salary
select 
SUM(salary) 总和,AVG(salary) 平均值,MAX(salary) 最大值,min(salary) 最小值,COUNT(salary) 非空值的数量
from employees
-- 计算表中绩效列不为空的员工数量
select COUNT(commission_pct) from employees
-- 求表中的行数
select COUNT(*) from employees
select COUNT(employee_id) from employees


二、MySQL的分组


在MySQL中一个组就是一个操作单位

简单分组

select 列名 from 表名 group by 列名

以部门为单位求每个部门的平均薪资

select department_id,AVG(salary) 平均薪资 from employees group by department_id

where + 分组


-- 查询部门id为10、20、30的部门的平均薪资、
select department_id,AVG(salary) 平均薪资 
from employees
where department_id in(10,20,30) -- 先筛选
GROUP BY department_id -- 后分组查询


having + 分组


select department_id,AVG(salary) 平均薪资 
from employees
group by department_id -- 先分组
having department_id in(10,20,30)  -- 后筛选


分组中 where 和 having 的区别


where是在分组前执行,having是在分组后执行

where不能在分组时使用组函数,但是having可以

当两者都可使用时,优先使用where,效率更高


三、分页以及查询关键字的执行顺序


limit:用来限制显示的查询结果条数,通常用于分页查询

select 列名 from 表名 limit 显示的起始下标,显示条数


查询所有员工数据的前十条

select * from employees limit 0,10

select * from employees limit 10 下标为0时可以省略

当limit和其他查询关键字联用时,limit一定最后执行


查询的执行顺序:


语法顺序  执行顺序


select    5
from    1
where   2
group by  3
having    4
order by  6
limit   7


四、子查询


当一个SQL需要借助于另一个SQL的执行结果,在当前SQL中嵌套另一个SQL,该写法称为子查询


1、where子查询


1.1、单值子查询


嵌套的子SQL只会返回一行一列的结果

-- 查询员工id为100的员工的部门id

select department_id from employees where employee_id=100


-- 子查询::查询员工id为100的员工所在的部门信息


select * from departments 
where department_id=(select department_id from employees where employee_id=100)


优先执行内层SQL,再执行外层SQL

子SQL需写入小括号

1.2、多值子查询

嵌套的子SQL会返回多个结果

--查询firstname中包含s的员工所在的部门信息


select * from departments 
where department_id in(select department_id from employees where first_name like '%s%')


2、from子查询


将子SQL的查询结果临时看做一张表进行后续操作
-- 获取薪资最高的前十个员工的平均薪资
-- 先获取薪资最高的前十名员工的薪资
select salary from employees ORDER BY salary desc LIMIT 10
-- 子查询:再根据子SQL的查询结果临时通过别名构建一张数据表进行查询
select avg(salary) from (select salary from employees ORDER BY salary desc LIMIT 10) as e


五、表连接


当查询结果需要从多张表中获取时,则需要将多张表连接起来进行查新操作

表连接的前提:


多张表之间必须存在关联关系(外键)

外键通常连接的是另一张表的主键

在进行表连接时作为连接条件使用


1、内连接

语法:


select 表1.列名,表2.列名,... 
from 表1 inner join 表2
on 连接条件


特点:对两张表同时进行约束,只有当所有表都符合连接条件,才会显示信息

使用:inner可省


2、(左)外连接

语法:


select 表1.列名,表2.列名,... 
from 表1(左表) left outer join 表2(右表)
on 连接条件


特点:只对右表做约束,左表中的数据都会显示,右表中只有符合连接条件的才会显示

使用:outer可省

左外连接和右外连接就是left和right的不同,位置不同,通常用左外连接

使用:

-- 查询所有的员工信息及符合连接条件的部门信息


select e.*,d.*
from employees e LEFT JOIN departments d
ON e.department_id=d.department_id


全外连接:


将两个查询结果进行合并显示

查询语句1 union 查询语句2

使用:


-- 内连接
select e.*,d.*  
from employees e inner join departments d
on  e.department_id=d.department_id
union -- 对内连接和左连接的查询结果进行合并
-- 左连接
select e.*,d.*
from employees e LEFT JOIN departments d
ON e.department_id=d.department_id


union会对合并结果进行去重

union all不会对结果去重

特点:合并双方都不做约束

合并双方的查询结果字段的个数、顺序必须一致

实际开发中,使用频率较高的是内连接和左外连接


3、自连接


概念:是特殊的表连接,参与连接的是同一张表

具体使用:


表中的某两个字段之间存在关联关系


-- 查询:员工id、员工姓名-firstname、直接领导的id、直接领导的姓名
select e1.employee_id 员工id,e1.first_name 员工姓名,e2.employee_id 领导id,e2.first_name 领导姓名
from employees e1 LEFT JOIN employees e2-- e1代表获取员工信息的表,e2代表获取领导信息的表
ON e1.manager_id=e2.employee_id -- 把两个有关联关系的字段作为连接条件


判断同一字段,作为连接条件


-- 查询工资相同的员工信息
select e1.employee_id 员工1的id,e1.salary 员工1的工资,e2.employee_id 员工2的id,e2.salary 员工2的工资
from employees e1 LEFT JOIN employees e2
on e1.salary=e2.salary -- 连接条件
where e1.employee_id<e2.employee_id -- 防止判断的双方是同一个人,并去重
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
缓存 关系型数据库 MySQL
MySQL索引策略与查询性能调优实战
在实际应用中,需要根据具体的业务需求和查询模式,综合运用索引策略和查询性能调优方法,不断地测试和优化,以提高MySQL数据库的查询性能。
234 66
|
22天前
|
SQL 关系型数据库 MySQL
【MySQL基础篇】盘点MySQL常用四大类函数
本文介绍了MySQL中的四大类常用函数:字符串函数、数值函数、日期函数和流程函数。
【MySQL基础篇】盘点MySQL常用四大类函数
|
26天前
|
存储 Oracle 关系型数据库
索引在手,查询无忧:MySQL索引简介
MySQL 是一款广泛使用的关系型数据库管理系统,在2024年5月的DB-Engines排名中得分1084,仅次于Oracle。本文介绍MySQL索引的工作原理和类型,包括B+Tree、Hash、Full-text索引,以及主键、唯一、普通索引等,帮助开发者优化查询性能。索引类似于图书馆的分类系统,能快速定位数据行,极大提高检索效率。
55 8
|
29天前
|
SQL 关系型数据库 MySQL
MySQL 窗口函数详解:分析性查询的强大工具
MySQL 窗口函数从 8.0 版本开始支持,提供了一种灵活的方式处理 SQL 查询中的数据。无需分组即可对行集进行分析,常用于计算排名、累计和、移动平均值等。基本语法包括 `function_name([arguments]) OVER ([PARTITION BY columns] [ORDER BY columns] [frame_clause])`,常见函数有 `ROW_NUMBER()`, `RANK()`, `DENSE_RANK()`, `SUM()`, `AVG()` 等。窗口框架定义了计算聚合值时应包含的行。适用于复杂数据操作和分析报告。
70 11
|
1月前
|
存储 关系型数据库 MySQL
mysql怎么查询longblob类型数据的大小
通过本文的介绍,希望您能深入理解如何查询MySQL中 `LONG BLOB`类型数据的大小,并结合优化技术提升查询性能,以满足实际业务需求。
110 6
|
1月前
|
SQL 关系型数据库 MySQL
MySQL常见函数第二期,你都用过哪些呢 ?
本期介绍了20个常用的MySQL函数,涵盖日期处理(如CURDATE()、DATE_FORMAT())、数学运算(如ABS()、ROUND())、统计分析(如COUNT()、SUM())等,帮助提高SQL查询效率和数据处理能力。希望对大家的学习有所帮助。
70 7
|
1月前
|
关系型数据库 MySQL
MySQL常见函数第一期,你都用过哪些呢 ?
本期介绍10个常用的MySQL函数:字符串连接(CONCAT)、提取子字符串(SUBSTRING)、获取字符串长度(LENGTH)、转换大小写(UPPER、LOWER)、去除空格(TRIM)、替换字符串(REPLACE)、查找子字符串位置(INSTR)、带分隔符的字符串连接(CONCAT_WS)以及获取当前日期时间(NOW)。
68 8
|
1月前
|
数据采集 关系型数据库 MySQL
MySQL常用函数:IF、SUM等用法
本文介绍了MySQL中常用的IF、SUM等函数及其用法,通过具体示例展示了如何利用这些函数进行条件判断、数值计算以及复杂查询。同时,文章还提到了CASE WHEN语句和其他常用函数,如COUNT、AVG、MAX/MIN等,强调了它们在数据统计分析、数据清洗和报表生成中的重要性。
|
1月前
|
关系型数据库 MySQL 数据处理
【MySQL】函数
MySQL 提供了丰富的函数集,涵盖字符串处理、数值运算、日期时间操作和聚合计算等多个方面。这些函数在日常数据库操作中极为重要,通过合理使用这些函数,可以大大提高数据处理和查询的效率。用户还可以通过自定义函数,扩展 MySQL 的功能以满足特定需求。
60 3
|
2月前
|
关系型数据库 MySQL 数据处理
MySQL函数与约束
MySQL 提供了丰富的函数和强大的约束机制,用于数据处理和完整性维护。通过掌握这些工具,可以有效地管理和分析数据库中的数据,确保数据的一致性和准确性。无论是在日常数据查询中使用内置函数,还是在数据库设计中应用各种约束,都是确保数据库系统稳定、高效运行的关键。希望本文对您理解和应用 MySQL 函数与约束有所帮助。
42 1