Mysql第二章 多表查询的操作

news/2024/10/30 10:23:47/

这里写自定义目录标题

  • 一 外连接与内连接的概念
    • sql99语法实现 默认是内连接
    • sql99语法实现左外连接,把没有部门的员工也查出来
    • sql99语法实现右外连接,把没有人的部门查出来
    • sql99语法实现满外连接,mysql不支持这样写
    • mysql中如果要实现满外连接的效果,推荐使用union关键字
  • 二 自连接和非自连接的概念
  • 三 等值连接和非等值连接的概念
    • 1.1 等值连接
    • 1.1 非等值连接
  • 四 七种JOIN的实现
    • 1 内连接 A∩B
    • 2 左外连接
    • 3 右外连接
    • 4 A - A∩B
    • 5 B - A∩B
    • 6 满外连接
    • 7 满外连接- 内连接
  • 五 natural join与USING

因为直接连接多表时,笛卡尔积的问题引出了多表联查的问题,多表查询基本分为三类,外连接和内连接,等值和非等值,自连接和非自连接

一 外连接与内连接的概念

这些连接关系,归根结底是集合的交并补运算
求出两个表的公共部分,叫做内连接,相当于是交集
求出两个表的公共部分加上左边的,叫做左外连接
如果是左外连接,则连接条件中左边的表也称为 主表 ,右边的表称为从表
如果是右外连接,则连接条件右边的表称为主表,左边的表称为从表

sql99语法实现 默认是内连接

SELECT last_name,department_name
FROM employees e INNER JOIN departments d
on e.department_id=d.department_id

结果显示为102条数据:
在这里插入图片描述

sql99语法实现左外连接,把没有部门的员工也查出来

SELECT last_name,department_name
FROM employees e LEFT  OUTER JOIN departments d
on e.department_id=d.department_id;

结果为103条数据
相当于是左边是员工表的全部信息,右边是部门表的部分信息
员工表和部门表的交集,e交d,和部门表为NULL但员工表有人的信息
在这里插入图片描述

在这里插入图片描述

sql99语法实现右外连接,把没有人的部门查出来

SELECT last_name,department_name
FROM employees e RIGHT  OUTER JOIN departments d
on e.department_id=d.department_id;

结果如图可见,有119条信息
在这里插入图片描述
也就是关键是右边的部门表,所以叫做,右外连接,首要查出的是所有的部门

在这里插入图片描述

sql99语法实现满外连接,mysql不支持这样写

SELECT  last_name,department_name
FROM employees e
FULL OUTER departments d
ON e.department_id=d.department_id 

mysql中如果要实现满外连接的效果,推荐使用union关键字

Union关键字,返回一个并集,类似于A并B,会执行去重检索的操作
union all 返回并集加上交集 ,优点是效率比较高

  • 查询部门编号>90或邮箱包含a的员工信息
SELECT * FROM employees WHERE email LIKE '%a%' 
UNION SELECT * FROM employees WHERE department_id>90;
  • 查询所有部门号和所有员工姓名,需要去重
#查找所有的员工名字,以及所有的部门
SELECT last_name,department_name
FROM employees e LEFT  OUTER JOIN departments d
on e.department_id=d.department_id
UNION 
SELECT last_name,department_name
FROM employees e RIGHT  OUTER JOIN departments d
on e.department_id=d.department_id;

结果显示出来118条信息
在这里插入图片描述
这里出现了一个问题,那就是,右外连接的数据,居然比去重后的并集数目还要多,以后再解决吧

  • 查询所有部门号和所有员工姓名,不需要去重
    结果222条信息
SELECT last_name,department_name
FROM employees e LEFT  OUTER JOIN departments d
on e.department_id=d.department_id
UNION ALL
SELECT last_name,department_name
FROM employees e RIGHT  OUTER JOIN departments d
on e.department_id=d.department_id;

二 自连接和非自连接的概念

  • 自连接,就是多表查询中自己引用自己
    查询员工id,员工姓名,管理者的ID和姓名
# 查询员工id,员工姓名,管理者的ID和姓名
SELECT emp.employee_id,emp.last_name,mgr.employee_id 经理工号,mgr.last_name 经理名字
FROM employees emp,employees mgr
WHERE emp.manager_id=mgr.employee_id;
  • 非自连接,普通的多表查询
SELECT last_name,department_name
FROM employees e INNER JOIN departments d
on e.department_id=d.department_id

三 等值连接和非等值连接的概念

1.1 等值连接

等值连接也称为显示内连接,在进行多表联合查询时通过“=”等号来连接多张表之间相字段对应的值,其产生的结果会出现重复列。意思是,如果对多张表进行等值连接操作,那么前提要求是这多张表之间必须有相同的字段名。,比方说一个表的主键是另一个表的外键

SELECT last_name,department_name
FROM employees e INNER JOIN departments d
on e.department_id=d.department_id

1.1 非等值连接

非等值连接最大的特点就是:连接条件中的关系是非等量关系
在这里插入图片描述
查询一个员工的名字,工资和所处的等级

SELECT last_name,salary,grade_level
FROM employees e,job_grades j
WHERE e.salary BETWEEN j.lowest_sal and j.highest_sal;

四 七种JOIN的实现

在这里插入图片描述

1 内连接 A∩B

# 内连接 A∩B
SELECT e.employee_id,e.last_name,d.department_name
FROM employees e
JOIN departments d
ON  e.department_id=d.department_id;

2 左外连接

SELECT e.employee_id,e.last_name,d.department_name
FROM employees e
LEFT JOIN departments d
ON e.department_id=d.department_id;

3 右外连接

# 右外连接,右边的项目作为主表,左边的是从表
SELECT e.employee_id,e.last_name,d.department_name
FROM employees e
RIGHT JOIN departments d 
ON e.department_id =d.department_id;

4 A - A∩B

# A - A∩B 有名字,没有部门
SELECT e.employee_id ,e.last_name,d.department_name
FROM employees e
LEFT JOIN departments d
ON e.department_id=d.department_id
WHERE d.department_id
IS NULL;

5 B - A∩B

SELECT employee_id,last_name,department_name
FROM employees e
RIGHT JOIN departments d
ON e.department_id=d.department_id
WHERE e.department_id
IS NULL;

6 满外连接

左外连接并上B - A∩B

SELECT employee_id,last_name,department_name
FROM employees e
RIGHT JOIN departments d
ON e.department_id=d.department_id
WHERE e.department_id
IS NULL
union all
SELECT e.employee_id,e.last_name,d.department_name
FROM employees e
LEFT JOIN departments d
ON e.department_id=d.department_id;

7 满外连接- 内连接

SELECT employee_id,last_name,department_name
FROM employees e
RIGHT JOIN departments d
ON e.department_id=d.department_id
WHERE e.department_id
IS NULL
union all
SELECT e.employee_id ,e.last_name,d.department_name
FROM employees e
LEFT JOIN departments d
ON e.department_id=d.department_id
WHERE d.department_id
IS NULL;

五 natural join与USING

自动查询两张连接表中 所有相同的字段 ,然后进行 等值 连接

SELECT employee_id,last_name,department_name 
FROM employees e NATURAL JOIN departments d;

USING相对于natural join 优化了一点

SELECT employee_id,last_name,department_name
FROM employees e JOIN departments d 
USING (department_id);

多表查询需要限制,太多了相当于多重for循环,消耗资源


http://www.ppmy.cn/news/107932.html

相关文章

以太坊Layer 2即将爆发!加密巨头入场布局,或将迎来“百链大战”!

眼下,以太坊Layer 2发展势头强劲。在数十条Rollup Layer 2异彩纷呈之际,Coinbase、ConsenSys等加密巨头也开始下场参与竞争,部署原生Layer 2网络。 截至2022年底,Layer 2解决方案的日均交易数在持续增加,甚至超过了以太…

在线帮助中心搭建利器:Baklib

帮助中心是一个提供服务和支持的虚拟平台,旨在为客户提供解决问题和获取信息的途径。它通常包含企业或组织的产品或服务的相关信息、解决方案、操作指南和常见问题等信息。通过帮助中心,用户可以自助查询并解决问题,从而提高了客户的满意度和…

Pulsar 负载均衡与transaction_coordinator_assign

背景与现状 TC加载到哪个broker上取决于transaction_coordinator_assign-partition-${TC ID}分区加载到哪个broker上。 默认transaction_coordinator_assign有16个分区,因此默认有16个TC,我们需要根据集群机器/broker数目来设置合理的TC个数。 为了保证…

PMBOK中的20个常用英文缩写及其含义

在项目管理的世界中,有许多常用的英文缩写。这些缩写代表了PMBOK(项目管理知识体系)中的重要概念和工具。对于初学者来说,熟悉这些缩写及其含义对于理解和运用项目管理的基本原则非常重要。 PMBOK: Project Management Body of Kn…

二叉搜索树(BST)详解及代码实现

推荐可视化插入、删除节点的二叉树网站:Binary Search Tree Visualization (usfca.edu) 1. 概述 二叉搜索树(Binary Search Tree,简称BST)是一种特殊的二叉树结构,它具有以下特点: 有序性:对于…

Python - numpy basic

目录 数组array的创建 1 通过list创建array 2 通过list创建二维数组 3 通过arange函数创建 等差数组 4 通过zeros函数创建 零矩阵 5 通过eyes函数创建 单位矩阵 数组array的访问 1 访问形状/元素个数/数据类型 2 访问一维数组的位置/范围 3 访问二维数组的位置/范围 4…

Pytorch神经网络常用函数介绍(持续更新……)

1. nn.Linear() 在深度学习中,nn.Linear()是 PyTorch 中用于定义线性层的类。它用于构建神经网络模型的线性层,将输入数据进行线性变换。nn.Linear()的参数用法如下: nn.Linear(in_features, out_features, biasTrue)参数解释如下&#xff…

【尔嵘】感恩四周年,感谢支持

前言 注意:为感谢各位铁粉支持,【尔嵘】将随机一个号码赠送一本vue.js书籍,欢迎评论区留言! 在当前互联网领域中,CSDN是一个非常知名的技术社区,在这里你可以接触到很多高质量的技术文章和技术交流。对于技…