Mysql之多表查询上篇

2023-11-05 22:30

本文主要是介绍Mysql之多表查询上篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Mysql之多表查询上篇

  • 多表查询
    • 什么是多表查询
    • 笛卡尔积(交叉连接)
      • 产生笛卡尔积的条件
      • 避免笛卡尔积的方法
  • 多表查询的分类
    • 1.等值连接 VS 非等值连接
      • 等值连接
      • 非等值连接
      • 扩展1表的别名
      • 扩展2:连接多个表
    • 2.自连接与非自连接
        • 扩展3:SQL语法标准
      • 内连接
        • SQL92语法实现内连接
        • SQL99语法实现内连接
      • 外连接
        • 左外连接
        • 右外连接
        • 满外连接

多表查询

什么是多表查询

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

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

笛卡尔积(交叉连接)

在学习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

在这里插入图片描述

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;

实际上这里内连接,是省略了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;

外连接

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

结果表中相应的列为空(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) ;

当然这里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) ;
右外连接
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) ;

当然这里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) ;
满外连接

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

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

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

这篇关于Mysql之多表查询上篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/352876

相关文章

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

MySQL多实例管理如何在一台主机上运行多个mysql

《MySQL多实例管理如何在一台主机上运行多个mysql》文章详解了在Linux主机上通过二进制方式安装MySQL多实例的步骤,涵盖端口配置、数据目录准备、初始化与启动流程,以及排错方法,适用于构建读... 目录一、什么是mysql多实例二、二进制方式安装MySQL1.获取二进制代码包2.安装基础依赖3.清

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、