【MySQL】多表查询

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 🎉多表查询🎈3.1 内连接查询🎈3.2 外连接查询🎈3.3 子查询最后说一句

在这里插入图片描述

@[toc]

🎉多表查询

🎈3.1 内连接查询

  • 语法
-- 隐式内连接
SELECT 字段列表 FROM 表1,表2… WHERE 条件;

-- 显示内连接
SELECT 字段列表 FROM 表1 [INNER] JOIN 表2 ON 条件;
内连接相当于查询 A B 交集数据

在这里插入图片描述

  • 案例

    • 隐式内连接

      SELECT
          *
      FROM
          emp,
          dept
      WHERE
          emp.dep_id = dept.did;

      执行上述语句结果如下:

      在这里插入图片描述

    • 查询 emp的 name, gender,dept表的dname

      SELECT
          emp. NAME,
          emp.gender,
          dept.dname
      FROM
          emp,
          dept
      WHERE
          emp.dep_id = dept.did;

      执行语句结果如下:

      在这里插入图片描述

上面语句中使用表名指定字段所属有点麻烦,sql也支持给表指别名,上述语句可以改进为

```sql
SELECT
    t1. NAME,
    t1.gender,
    t2.dname
FROM
    emp t1,
    dept t2
WHERE
    t1.dep_id = t2.did;
```
  • 显式内连接

    select * from emp inner join dept on emp.dep_id = dept.did;
    -- 上面语句中的inner可以省略,可以书写为如下语句
    select * from emp  join dept on emp.dep_id = dept.did;

    执行结果如下:

    在这里插入图片描述

🎈3.2 外连接查询

  • 语法

    -- 左外连接
    SELECT 字段列表 FROM 表1 LEFT [OUTER] JOIN 表2 ON 条件;
    
    -- 右外连接
    SELECT 字段列表 FROM 表1 RIGHT [OUTER] JOIN 表2 ON 条件;
    左外连接:相当于查询A表所有数据和交集部分数据

    右外连接:相当于查询B表所有数据和交集部分数据

    在这里插入图片描述

  • 案例

    • 查询emp表所有数据和对应的部门信息(左外连接)

      select * from emp left join dept on emp.dep_id = dept.did;

      执行语句结果如下:

      在这里插入图片描述

结果显示查询到了左表(emp)中所有的数据及两张表能关联的数据。
  • 查询dept表所有数据和对应的员工信息(右外连接)

    select * from emp right join dept on emp.dep_id = dept.did;

    执行语句结果如下:

    在这里插入图片描述

结果显示查询到了右表(dept)中所有的数据及两张表能关联的数据。

要查询出部门表中所有的数据,也可以通过左外连接实现,只需要将两个表的位置进行互换:

```sql
select * from dept left join emp on emp.dep_id = dept.did;
```


🎈3.3 子查询

  • 概念

    ==查询中嵌套查询,称嵌套查询为子查询。==

    什么是查询中嵌套查询呢?我们通过一个例子来看:

    需求:查询工资高于猪八戒的员工信息。

    来实现这个需求,我们就可以通过二步实现,第一步:先查询出来 猪八戒的工资

    select salary from emp where name = '猪八戒'

    第二步:查询工资高于猪八戒的员工信息

    select * from emp where salary > 3600;

    第二步中的3600可以通过第一步的sql查询出来,所以将3600用第一步的sql语句进行替换

    select * from emp where salary > (select salary from emp where name = '猪八戒');

    这就是查询语句中嵌套查询语句。

  • 子查询根据查询结果不同,作用不同

    • 子查询语句结果是单行单列,子查询语句作为条件值,使用 = != > < 等进行条件判断
    • 子查询语句结果是多行单列,子查询语句作为条件值,使用 in 等关键字进行条件判断
    • 子查询语句结果是多行多列,子查询语句作为虚拟表
  • 案例

    • 查询 '财务部' 和 '市场部' 所有的员工信息

      -- 查询 '财务部' 或者 '市场部' 所有的员工的部门did
      select did from dept where dname = '财务部' or dname = '市场部';
      
      select * from emp where dep_id in (select did from dept where dname = '财务部' or dname = '市场部');
    • 查询入职日期是 '2011-11-11' 之后的员工信息和部门信息

      -- 查询入职日期是 '2011-11-11' 之后的员工信息
      select * from emp where join_date > '2011-11-11' ;
      -- 将上面语句的结果作为虚拟表和dept表进行内连接查询
      select * from (select * from emp where join_date > '2011-11-11' ) t1, dept where t1.dep_id = dept.did;

最后说一句

感谢大家的阅读,文章通过网络资源与自己的学习过程整理出来,希望能帮助到大家。

才疏学浅,难免会有纰漏,如果你发现了错误的地方,可以提出来,我会对其加以修改。

在这里插入图片描述

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6天前
|
SQL 存储 关系型数据库
轻松入门MySQL:数据库关联与多表查询,构建高效的业务决策引擎(6)
轻松入门MySQL:数据库关联与多表查询,构建高效的业务决策引擎(6)
|
6天前
|
SQL 关系型数据库 MySQL
MySQL多表查询 子查询效率(DQL语句)
MySQL多表查询 子查询效率(DQL语句)
41 0
|
6天前
|
SQL 关系型数据库 MySQL
⑧【MySQL】数据库查询:内连接、外连接、自连接、子查询、多表查询
⑧【MySQL】数据库查询:内连接、外连接、自连接、子查询、多表查询
98 0
|
6天前
|
关系型数据库 MySQL
3. Mysql 如何实现多表查询
MySQL多表查询主要包括内连接和外连接。内连接有隐式和显式:隐式是通过`From 表A, 表B where 连接条件`,显式是`From 表A inner join 表B on 连接条件`。外连接包括左外连接(`left join`)、右外连接(`right join`)和全外连接(较少使用)。此外,还有交叉连接(`cross join`),但也较少使用。
21 0
|
6天前
|
SQL 关系型数据库 MySQL
【Mysql】在多表查询过程中如果已经起了别名,就不能通过表名限定字段
【Mysql】在多表查询过程中如果已经起了别名,就不能通过表名限定字段
|
6天前
|
SQL 数据可视化 关系型数据库
【MySQL-11】多表查询全解-【多表关系/内外自连接/子查询/多表查询案例链接】(可cv代码&案例演示)
【MySQL-11】多表查询全解-【多表关系/内外自连接/子查询/多表查询案例链接】(可cv代码&案例演示)
|
6天前
|
存储 SQL 关系型数据库
MySQL表的增删改查---多表查询和联合查询
MySQL表的增删改查---多表查询和联合查询
|
6天前
|
SQL 关系型数据库 MySQL
【MySQL探索之旅】多表查询
【MySQL探索之旅】多表查询
|
6天前
|
SQL 关系型数据库 MySQL
MySQL 多表查询
MySQL 多表查询
19 0
|
6天前
|
SQL 关系型数据库 vr&ar
多表查询——“MySQL数据库”
多表查询——“MySQL数据库”