返回顶部
首页 > 资讯 > 数据库 >MySQL多表查询
  • 901
分享到

MySQL多表查询

mysql数据库sql 2023-09-01 21:09:15 901人浏览 安东尼
摘要

文章目录 一、什么是多表查询1、概述2、笛卡尔积现象 二、多表查询的分类1、等值连接 vs非等值连接2、自连接 vs 非自连接3、内连接 vs 外连接4、满外连接(FULL OUTE

文章目录

一、什么是多表查询

1、概述

多表查询就是从多张表中去查询数据,在实际开发中大多数情况数据都是存储在多张中的,它们通过一个关联关系连接起来,这样就可以通过这个关联关系去查询到想要的数据。比如:下面两个表的数据就是通过stu_num这个字段关联的,通过stu_num即可查询到此名学生的成绩。
关联关系:可以是一对一,也可以是一对多的关系
学生信息在这里插入图片描述
(关于这两张表的sql在文章最后附录中)

2、笛卡尔积现象

上文提到了需要通过一个关联关系连接起来,如果不通过关系连接会出现什么情况呢?答案就是笛卡尔积现象

(1)、使用此SQL去查询观察结果:
SELECT * FROM t_student,t_score
查询出了两个表的全部组合结果,共计49条记录。
在这里插入图片描述
(图片中只展示了部分数据)

(2)、使用连接关系查询结果:
SELECT * FROM t_student,t_score WHERE t_student.stu_num = t_score.stu_num
查询出期望的结果6条记录,因为关联关系是字段stu_num,所有可以对应查询到的结果只有6条记录。
在这里插入图片描述

(3)、查询出最终结果(可以设置别名查询想要的列)

SELECT a.stu_num,a.stu_name,a.stu_age,b.stu_score FROM t_student a,t_score b WHERE a.stu_num = b.stu_num   # 关联关系

在这里插入图片描述

二、多表查询的分类

1、等值连接 vs非等值连接

等值连接:就是通过一个表的字段和另一个表的字段相等来连接

SELECT a.stu_num,a.stu_name,a.stu_age,b.stu_score FROM t_student a,t_score b WHERE a.stu_num = b.stu_num

在这里插入图片描述

非等值连接:不是这种两表之间通过字段相等的连接。例如我们统计每个学生的分数在那个等级
在这里插入图片描述
(引入第三张表,成绩等级表)

SELECT* FROMt_score a,t_grade bWHEREa.stu_score BETWEEN b.score_min and b.score_max

在这里插入图片描述
3、连接多张表
如果想查查询出最终的结果需要连接三张表才可以。

SELECTa.stu_num,a.stu_name,a.stu_age,b.stu_score,c.score_grade FROMt_student a,t_score b,t_grade c WHEREa.stu_num = b.stu_num AND b.stu_score BETWEEN c.score_min AND c.score_max

在这里插入图片描述

2、自连接 vs 非自连接

(1)、自连接:就是同一张表,利用取别名的方式虚拟成两张表以代表不同的意义的表,然后这两个表再进行内连接或者外连接。

SELECTa.employee_id,a.employee_name,b.employee_name as manager_name FROMt_employee a,t_employee b WHEREa.manager_id = b.employee_id

在这里插入图片描述
只有两条记录是因为只有依据连接关系只又两条记录符合条件

(2)、非自连接:不同表之间进行连接

3、内连接 vs 外连接

(1)、内连接:只查出符合关联条件的记录。上面的所有连接均为内连接
语法:
a、直接在from后面接关联表,where后面写关联关系

SELECTa.stu_num,a.stu_name,a.stu_age,b.stu_score FROMt_student a,t_score b WHEREa.stu_num = b.stu_num

b、INNER JOIN 表名 ON 关联关系 WHERE 其他条件 ,其中INNER可以省略不写

SELECTa.stu_num,a.stu_name,a.stu_age,b.stu_score FROMt_student aINNER JOIN t_score b ON a.stu_num = b.stu_num

查询结果
在这里插入图片描述

(2)、外连接:外连接分为左外连接和右外连接。
左外连接:在查出符合关联条件的同时会将左表中的记录全部展示出来,没有关联到记录右表补充为null。
语法:LEFT OUTER JOIN 表名 ON 关联关系 WHERE 其他条件,其中OUTER可以省略

  • 例一:查出所有学生的成绩

在这里插入图片描述

  • 例一SQL:
SELECTa.stu_num,a.stu_name,a.stu_age,b.stu_score FROMt_student aLEFT JOIN t_score b ON a.stu_num = b.stu_num
  • 例二:查出所有员工和他们的经理
    在这里插入图片描述
  • 例二SQL
SELECTa.employee_id,a.employee_name,b.employee_name AS manager_name FROMt_employee aLEFT JOIN t_employee b ON a.manager_id = b.employee_id

右外连接:在查出符合关联条件的同时会将右表中的记录全部展示出来,没有关联到记录左表补充为null。
语法:RIGHT OUTER JOIN 表名 ON 关联关系 WHERE 其他条件,其中OUTER可以省略

  • 例三:查询所有成绩对应的学生信息

在这里插入图片描述

  • 例三SQL
SELECTa.stu_num,a.stu_name,a.stu_age,b.stu_score FROMt_student aRIGHT JOIN t_score b ON a.stu_num = b.stu_num
  • 例四:查询所有经理的员工
    在这里插入图片描述

  • 例四SQL

SELECTa.employee_id,a.employee_name,b.employee_name AS manager_name FROMt_employee aRIGHT JOIN t_employee b ON a.manager_id = b.employee_id

4、满外连接(FULL OUTER JOIN)

  • 满外连接的结果 = 左右表匹配的数据 + 左表没有匹配到的数据 + 右表没有匹配到的数据。
  • SQL99是支持满外连接的。使用FULL JOIN 或 FULL OUTER JOIN来实现。
  • 需要注意的是,Mysql不支持FULL JOIN,但是可以用 LEFT JOIN UNION RIGHT join代替

三、UNioN[ALL]的使用

利用UNION关键字,可以给出多条SELECT语句,并将它们的结果组合成单个结果集。其中UNION ALL不会对结果集去重,但是效率较高,日常开发中更建议使用UNION All

条件:两个表对应的列数和数据类型必须相同,并且相互对应
语法

SELECT column,... FROM table1UNION [ALL]SELECT column,... FROM table2

演示

  • 例五:查询stu_num小于5和stu_age大于10的全部记录

在这里插入图片描述

  • 例五SQL
SELECT stu_num,stu_name,stu_age FROM t_student WHERE stu_num < 5 UNION ALL SELECT stu_num, stu_name, stu_age FROM t_student WHERE stu_age > 10
  • 例六:查询stu_num小于5和stu_age大于10的全部记录,去除重复
    在这里插入图片描述
  • 例六SQL
SELECT stu_num,stu_name,stu_age FROM t_student WHERE stu_num < 5 UNIONSELECT stu_num, stu_name, stu_age FROM t_student WHERE stu_age > 10

四、7种SQL JOINS的实现

在这里插入图片描述

来源地址:https://blog.csdn.net/qq_46307070/article/details/126571024

您可能感兴趣的文档:

--结束END--

本文标题: MySQL多表查询

本文链接: https://www.lsjlt.com/news/389713.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作