• Mysql之多表查询上篇


    多表查询

    什么是多表查询

    多表查询,也称为关联查询,指两个或更多个表一起完成查询操作。

    前提条件:这些一起查询的表之间是有关系的(一对一、一对多),它们之间一定是有关联字段,这个关联字段可能建立了外键,也可能没有建立外键。比如:员工表和部门表,这两个表依靠“部门编号”进行关联

    笛卡尔积(交叉连接)

    在学习MySQL的表连接时,笛卡尔积是必须知道的一个概念。
    在没有任何限制条件的情况下,两表连接必然会形成笛卡尔积。

    如果表1有m行a列,表2有n行b列,两表无条件连接时会将两表里所有行两两组合到一起,所形成的表就有m*n行,a+b列。
    如果表1或表2的记录数很多时,连接后会形成一张非常大的表,在这种大表里查询效率特别低,所以在数据库查询时,应尽量避免笛卡尔积的出现

    产生笛卡尔积的条件

    1. 省略多个表的连接条件(或关联条件)
      2.连接条件(或关联条件)无效
      3.所有表中的所有行互相连接

    避免笛卡尔积的方法

    用where,添加连接条件

    注意:
    如果表中有相同的列,那么要在这列前面加上表的前缀在这里插入图片描述

    多表查询的分类

    1.等值连接 VS 非等值连接

    等值连接

    在这里插入图片描述

    如果所示,这种的就是等值连接,表中有相同的列,并且列的值都对应相等

    非等值连接

    在这里插入图片描述

    如图所示,这就是非等值连接的例子

    扩展1表的别名

    用表的别名

    1. 使用别名可以简化查询。
      2.列名前使用表名前缀可以提高查询效率

    需要注意的是,如果我们使用了表的别名,在查询字段中、过滤条件中就只能使用别名进行代替, 不能使用原有的表名,否则就会报错

    扩展2:连接多个表

    连接 n个表,至少需要n-1个连接条件。
    比如,连接三个表,至少需要两个连接条件

    2.自连接与非自连接

    扩展3:SQL语法标准

    SQL的语法标准,主要的就是SQL92语法和SQL99语法
    92语法就是1992年颁布的,99语法就是1999年颁布的
    99语法比92语法更多,完善了一些92语法

    在这里插入图片描述

    内连接

    内连接: 合并具有同一列的两个以上的表的行, 结果集中不包含一个表与另一个表不匹配的行

    SQL92语法实现内连接
    #SQL 92语法 实现内连接
    SELECT employee_id, department_name
    FROM employees e, departments d 
    WHERE e.employee_id = d.department_id
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述

    SQL99语法实现内连接

    99语法中,去掉了92语法的 ,
    改成以JOIN ON的形式,来实现内连接

    #SQL99语法实现内连接
    SELECT employee_id, department_name, city
    FROM employees e JOIN departments d
    ON e.employee_id = d.department_id
    JOIN locations l 
    ON d.department_id = l.location_id;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    实际上这里内连接,是省略了INNER, 这里默认是INNER,你也可以加上

    #SQL99语法实现内连接
    SELECT employee_id, department_name, city
    FROM employees e INNER JOIN departments d
    ON e.employee_id = d.department_id
    JOIN locations l 
    ON d.department_id = l.location_id;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    外连接

    外连接: 两个表在连接过程中除了返回满足连接条件的行以外还返回左(或右)表中不满足条件的 行 ,这种连接称为左(或右) 外连接。没有匹配的行时

    结果表中相应的列为空(NULL)。 如果是左外连接,则连接条件中左边的表也称为 主表 ,右边的表称为 从表 。
    如果是右外连接,则连接条件中右边的表也称为 主表 ,左边的表称为 从表

    注意:SQL92语法不支持实现外连接
    所以我们采用SQL99语法来实现外连接
    其实在JOIN前面,加一个OUTER,关键字便可以实现外连接

    左外连接
    SELECT e.last_name, e.department_id, d.department_name
    FROM employees e LEFT OUTER JOIN departments d
    ON (e.department_id = d.department_id) ;
    
    • 1
    • 2
    • 3

    当然这里JOIN前面的OUTER, 可以省略
    直接就LEFT JOIN

    SELECT e.last_name, e.department_id, d.department_name
    FROM employees e LEFT JOIN departments d
    ON (e.department_id = d.department_id) ;
    
    • 1
    • 2
    • 3
    右外连接
    SELECT e.last_name, e.department_id, d.department_name
    FROM employees e RIGHT OUTER JOIN departments d
    ON (e.department_id = d.department_id) ;
    
    • 1
    • 2
    • 3

    当然这里JOIN前面的OUTER, 可以省略
    直接就LEFT JOIN

    SELECT e.last_name, e.department_id, d.department_name
    FROM employees e RIGHT JOIN departments d
    ON (e.department_id = d.department_id) ;
    
    • 1
    • 2
    • 3
    满外连接

    满外连接的结果 = 左右表匹配的数据 + 左表没有匹配到的数据 + 右表没有匹配到的数据

    SQL99是支持满外连接的。使用FULL JOIN 或 FULL OUTER JOIN来实现。
    需要注意的是,MySQL不支持FULL JOIN

    具体怎么实现,多表查询下篇将为大家介绍

  • 相关阅读:
    hadoop伪分布模式配置
    躲避雪糕刺客?通过爬虫爬取雪糕价格
    大数据扫黄,是真的吗?
    DPDK EAL
    Thinkphp资源源码付费下载站网站源码
    C++模板编程(21)---C++实例化实现方案implementation Schemes
    Mysql之部分表主从搭建及新增表
    iNFTnews | 虚拟租赁是Web3的下一个发展方向
    【零基础学QT】第四章 控件学习方法,问卷调查小界面
    在RISC-V64架构的CV1811C开发板上应用perf工具进行多线程程序性能分析及火焰图调试
  • 原文地址:https://blog.csdn.net/m0_74228185/article/details/134228430