MySQL多表查询的案例详解
作者:T,a,o 发布时间:2024-01-24 13:11:26
多表查询
案列说明
笛卡尔积的理解
select id,department_name
from employees,departments;#错的
select id,department_id,department_name
from employees CROSS JOIN departments;#错的
每个员工和每个部门匹配了一遍(查出的条目数=id数*department数)
错误原因:缺少连接条件
笛卡尔积的解决
编写连接条件: 表1.列 = 表二.列(若多个表连接,至少要用n-1个连接条件)
select id,employees.name,department_name
from employees,departments
WHERE employees.name = departments.name;
注:如果要显示的列在要查询的表中名字一样,则要表明,是出自哪个表, eg: employees.name
建议在多表查询时,标明显示的是哪个表的信息 (优化)
优化:可以在FROM后使用表的别名,但是一旦使用别名,后续就一定要都用别名
多表查询的分类
等值连接和非等值连接
等值连接:上述的带有=的
非等值连接:没有=的
select t1.id,t1.name,t2.grade
from employees t1,departments t2
WHERE ti.salary BETWEEN t2.lowest_salary AND t2.highest_salary ;#非等值
自连接和非自连接
非自链接:表1和表2连接
自链接:表1和自己连接
#显示员工(t1)和其管理者(t2)的基本信息
select t1.id,t1.name,t2.id,t2.name
from employees t1,employees t2#一个表看作两个表
WHERE t1.manage_id = t2.id ;#自连接
内连接和外连接
内连接:合并含有同一列的表,结果不包括一个表与另一个表不匹配打的行
外连接:合并含有同一列的表,结果除了内连接的结果还查询不匹配的行
外连接的分类:左外连接(左表多,补右边),右外连接(右表多,补左边),满外连接
SQL92:使用(+)创建连接
内连接:见上
外连接:左表有数据不匹配,在右表加(+);反之,在左表加(+),但是MySQL不支持
WHERE t1.department_id = t2.department_id(+)#左连接
SQL99:使用JOIN...ON的方式
内连接
select t1.id,t1.name,t2.department_name,t3.environment
from employees t1 JOIN departments t2
ON t1.department_id = t2.department_id
JOIN locations t3#加入第二个人表
ON t2.department_location = t3.department_location;
外连接
使用OUTER JOIN...ON...
左外连接:LEFT OUTER JOIN
右外连接:RIGHT OUTER JOIN
满外连接:FULL OUTER JOIN(MySQL不支持)
select t1.name,t2.department_name#左外连接
from employees t1 LEFT OUTER(可省略) JOIN departments t2
ON t1.department_id = t2.department_id;
UMION的使用
合并查询结果
SELECT colum... FROM table1
UNION (ALL)
SELECT colum... FROM table2
UNION操作符
两个查询结果的并集,去重(效率低)
UNION ALL操作符(推荐)
两个查询结果的并集,不去重(效率高)
7种SQL JOINS的实现
中图(内连接):
select t1.name,t2.department_name
from employees t1 JOIN departments t2
ON t1.department_id = t2.department_id;
左上图(左外连接):
select t1.name,t2.department_name
from employees t1 LEFT JOIN departments t2
ON t1.department_id = t2.department_id;
右上图(右外连接):
select t1.name,t2.department_name
from employees t1 RIGHT JOIN departments t2
ON t1.department_id = t2.department_id;
左中图:
select t1.name,t2.department_name
from employees t1 LEFT JOIN departments t2
ON t1.department_id = t2.department_id
WHERE t2.department_id IS NULL;
右中图:
select t1.name,t2.department_name
from employees t1 RIGHT JOIN departments t2
ON t1.department_id = t2.department_id
WHERE t1.department_id IS NULL;
左下图(满外连接):
#方式一:左上图 UNION ALL 右中图
select t1.name,t2.department_name
from employees t1 LEFT JOIN departments t2
ON t1.department_id = t2.department_id
UNION ALL
select t1.name,t2.department_name
from employees t1 RIGHT JOIN departments t2
ON t1.department_id = t2.department_id
WHERE t1.department_id IS NULL;
#方式二:左中图 UNION ALL 右上图
select t1.name,t2.department_name
from employees t1 LEFT JOIN departments t2
ON t1.department_id = t2.department_id
WHERE t2.department_id IS NULL
UNION ALL
select t1.name,t2.department_name
from employees t1 RIGHT JOIN departments t2
ON t1.department_id = t2.department_id;
右下图:
#左中图 UNION ALL 右中图
select t1.name,t2.department_name
from employees t1 LEFT JOIN departments t2
ON t1.department_id = t2.department_id
WHERE t2.department_id IS NULL
UNION ALL
select t1.name,t2.department_name
from employees t1 RIGHT JOIN departments t2
ON t1.department_id = t2.department_id
WHERE t1.department_id IS NULL;
SQL语法新特性
自然连接
使用关键字:NATURAL JOIN(不灵活),自动查询表中所有相同字段,然后进行等值连接
USING连接(不适用于自连接)
使用关键字:USING(同名字段),将表中相同名字的字段自动等值连接
select t1.name,t2.department_name
from employees t1 JOIN departments t2
ON t1.department_id = t2.department_id;
等价于
select t1.name,t2.department_name
from employees t1 JOIN departments t2
USING(department_id);
来源:https://www.cnblogs.com/wht-de-bk/archive/2022/03/04/15966054.html
猜你喜欢
- 阅读上一篇:WEB2.0网页制作标准教程(11)不用表格的菜单辛苦了好多天,我们努力学习使用XHTML+CSS来重新设计我们的网站。那么我们
- python文件可以直接使用命令python xxx.py来启动文件,但是这样会有一个弊端,就是关闭ssh连接,python文件就会自动的进
- 从前有三只小猪,长大自立了分别造房子住。老大搬来草堆堆出草屋,老二搬来木头搭出木屋,老三搬来砖头,砌墙,造烟囱,造出了坚固的砖房。一天晚上大
- 当今互联网时代,数据处理已经成为了一个非常重要的任务。而MySQL作为一款开源的关系型数据库,被广泛应用于各种场景。本篇博客将介绍如何使用P
- 1. 引言本文重点介绍Python中的三个特殊函数Map,Filter和Reduce,以及如何使用它们进行代码编程。在开始介绍之前,我们先来
- 往期学习:python数据类型: python数据结构:数据类型.python的输入输出: python数据结构之输入输出及控制和异常.py
- 本文实例讲述了Selenium元素的常用操作方法。分享给大家供大家参考,具体如下:Selenium是一个用于Web应用程序测试的工具。Sel
- 方法一 declare @max integer,@id integer declare cur_r
- 操作步骤导入框架,import unitest测试类必须继承类:.class 类名(unittest.TestCase):在类中所有定义te
- 相信大家对街边林林总总的房产中介并不陌生,那么我们先看看下面这张图片。图1从右侧这家店的橱窗里,我们能迅速分清哪些是租房信息哪些是售房信息。
- 这篇文章主要介绍了Python pygame绘制文字制作滚动文字过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考
- php ffmpeg获取视频缩略图1.环境centos 7ffmpeg version 2.8.15 Copyright2.centos7安
- 本文实例讲述了Python图像的增强处理操作。分享给大家供大家参考,具体如下:python中PIL模块中有一个叫做ImageEnhance的
- 运用webbrowser库中的一个函数实现自动打开浏览器:webbrowser.open(http://blog.csdn.net/ares
- ping的原理是发送一个ICMP请求包,然后根据目的地址的应答包来判断是否能够和这个主机进行通信。我们使用python实现,借助于scapy
- 在JavaScript中有三种声明变量的方式:var、let、const。下文给大家介绍js中三种定义变量的方式const, var, le
- 中小站点简单备份策略基于drupal的中小行网站,我们可以使用backup_migrate模块,该模块提供了定期备份的功能,备份的时间、保留
- 创建RandomWalk类为模拟随机漫步,我们将创建一个RandomWalk类,随机选择前进方向,这个类有三个属性,一个存储随机漫步的次数,
- 网上看到一些例子,对于一个简单的3 级联动,都加上什么Struts, Hibernate诸如此类的框架。这个Ajax联动殊不知和这些框架有什
- 本文实例为大家分享了Vue实现通知或详情类弹窗的具体代码,供大家参考,具体内容如下效果如图所示:(整体样式模仿ant-design-vue