MySQL之复合查询解读

 更新时间:2025年08月11日 10:14:25   作者:每天敲200行代码  
本文系统讲解SQL查询技术,涵盖基本查询(条件筛选、排序、聚合)、多表连接、自连接、子查询(单行/多行/多列)及合并查询(UNION/UNION ALL),通过emp、dept、salgrade三张表演示员工与部门数据关联分析方法

一、基本查询练习回顾

1、查询工资高于 500 或岗位为 MANAGER 的雇员,同时还要满足他们的姓名首字母为大写的 J

2、按照部门号升序而雇员的工资降序排序

3、使用年薪进行降序排序

4、显示工资最高的员工的名字和工作岗位

5、显示工资高于平均工资的员工信息

6、显示每个部门的平均工资和最高工资

7、显示平均工资低于2000的部门号和它的平均工资

8、显示每种岗位的雇员总数,平均工资

二、多表查询

实际开发中往往数据来自不同的表,所以需要多表查询。这里我们用一个简单的公司管理系统,有三张表 emp,dept,salgrade 来演示如何进行多表查询。

⚪练习

1、显示雇员名、雇员工资以及所在部门的名字因为上面的数据来自 emp 和 dept 表,因此要联合查询(将数据进行穷举组合 —— 笛卡尔积)

其实我们只要 emp 表中的 deptno=dept 表中的 deptno 字段的记录:

2、显示部门号为 10 的部门名,员工名和工资

3、显示各个员工的姓名,工资,及工资级别

三、自连接

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

⚪练习

1、显示员工 FORD 的上级领导的编号和姓名(mgr 是员工领导的编号 —— empno)

(1)使用的子查询

先找 FORD 的上级领导的编号(emp),再根据领导的编号来找领导的信息(emp)。

(2)使用多表查询(自查询)

  • 使用到表的别名

from emp e1, emp e2,给自己的表起别名,因为要先做笛卡尔积,所以别名可以先识别。

四、子查询

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

  • 目前学习到的子查询都在 where 子句中充当判断条件。
  • 任何时刻,查询出来的临时结构,本质在逻辑上也是表结构。

1、单行子查询

返回一行记录的子查询。

  • 显示 SMITH 同一部门的员工

2、多行子查询

返回多行记录的子查询。

(1)in 关键字

in 关键字用来判断一个对应的列值是否在某个集合当中,只要在集合当中,说明查找成功。

查询和  10  号部门的工作岗位相同的雇员的名字,岗位,工资,部门号,但是不包含  10  自己的。

扩展:除了上面的要求以外,还需要显示出对应员工所属岗位的名字。

(2)all 关键字

all 关键字表示与所有的值作比较。

显示工资比部门  30  的所有员工的工资高的员工的姓名、工资和部门号。

另一种写法:

(3)any 关键字

amy 关键字表示与任意的值作比较。

显示工资比部门 30 的任意员工的工资高的员工的姓名、工资和部门号(包含自己部门的员工)。

3、多列子查询

  • 单行子查询是指子查询只返回单列,单行数据。
  • 多行子查询是指返回单列多行数据,都是针对单列而言的,而多列子查询则是指查询返回多个列数据的子查询语句。

⚪练习

查询和 SMITH 的部门和岗位完全相同的所有雇员,不含 SMITH 本人

4、在 from 子句中使用子查询

子查询语句出现在  from  子句中。

这里要用到数据查询的技巧,把一个子查询当做一个临时表使用。

⚪练习

(1)显示每个高于自己部门平均工资的员工的姓名、部门、工资、平均工资

  • 获取各个部门的平均工资,将其看作临时表

扩展:除了上面的要求以外,还需要显示出对应部门的办公地点。

(2)查找每个部门工资最高的人的姓名、工资、部门、最高工资

(3)显示每个部门的信息(部门名,编号,地址)和人员数量

a. 方法 1:使用多表

解决多表问题的本质:(多表的指导思想)

想办法将多表转化为单表,所以在 MySQL 中,所有 select 的问题全都可以转成单表问题。 

b. 方法 2:使用子查询(推荐)

  • 对 emp 表进行人员统计

  • 将上面的表看作临时表

5、合并查询

在实际应用中,为了合并多个  select  的执行结果,可以使用集合操作符 union , union all。

(1)union

该操作符用于取得两个结果集的并集。当使用该操作符时, 自动去掉结果集中的重复行。

练习 —— 将工资大于 2500 或职位是 MANAGER 的人找出来

(2)union all

该操作符用于取得两个结果集的并集。当使用该操作符时,不会去掉结果集中的重复行。

练习 —— 将工资大于 25000 或职位是 MANAGER 的人找出来

注意:select 如果要使用 union / union all 来拼接两个结果,前提是必须保证两个表的列数是相同的。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Mysql之SQL执行流程全面解析

    Mysql之SQL执行流程全面解析

    MySQL的执行流程包括查询缓存、解析器、优化器和执行器,首先,查询缓存检查是否存在查询结果,如果存在则直接返回;如果不存在,则进入解析器进行语法和语义分析,解析器将SQL语句转换为语法树,并进行词法和语法分析,接着,优化器确定最佳执行路径
    2024-12-12
  • 一文弄懂MySQL中redo log与binlog的区别

    一文弄懂MySQL中redo log与binlog的区别

    在学习mysql数据库时,不可避免要去接触到redo log和binlog,好多人对这两者的概念分不太清,下面这篇文章主要给大家介绍了关于MySQL中redo log与binlog区别的相关资料,需要的朋友可以参考下
    2022-02-02
  • 重置MySQL 8.0 Root密码的简便方法小结

    重置MySQL 8.0 Root密码的简便方法小结

    这篇文章主要给大家介绍了几种轻松重置 MySQL 8.0 Root 密码的简便方法,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-10-10
  • MySQL 丢失数据的原因及解决

    MySQL 丢失数据的原因及解决

    这篇文章主要介绍了MySQL 丢失数据的原因及解决,帮助大家更好的理解和学习使用MySQL数据库,感兴趣的朋友可以了解下
    2021-05-05
  • MySQL实现批量更新不同表中的数据

    MySQL实现批量更新不同表中的数据

    这篇文章主要介绍了MySQL实现批量更新不同表中的数据,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • mysql查询使用_rowid虚拟列的示例

    mysql查询使用_rowid虚拟列的示例

    MySQL中,_rowid是InnoDB虚拟列,用于无主键表的行ID查询,若存在主键或唯一列,则指向其,否则使用隐藏ID(不稳定),推荐使用ROW_NUMBER()或变量模拟,且应显式定义主键以确保稳定性,对mysql,_rowid虚拟列相关知识感兴趣的朋友一起看看吧
    2025-06-06
  • MySQL中查找重复值的实现

    MySQL中查找重复值的实现

    查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下
    2025-07-07
  • MySQL中字段类型为longtext的值导出后显示二进制串方式

    MySQL中字段类型为longtext的值导出后显示二进制串方式

    这篇文章主要介绍了MySQL中字段类型为longtext的值导出后显示二进制串方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • mysql自动备份多个数据库的实现

    mysql自动备份多个数据库的实现

    本文主要介绍了mysql自动备份多个数据库的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • 如何设置mysql数据库只读权限用户及全部权限

    如何设置mysql数据库只读权限用户及全部权限

    MySQL数据库所有用户权限是指MySQL数据库中可以对数据库和表进行操作的权限,这篇文章主要介绍了如何设置mysql数据库只读权限用户及全部权限的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-11-11

最新评论