MySQL内外连接的具体使用

作者:2021dragon 时间:2024-01-17 13:52:49 

MySQL内外连接

表的连接分为内连接和外连接。

内连接

内连接

内连接的SQL如下:

SELECT ... FROM t1 INNER JOIN t2 ON 连接条件 [INNER JOIN t3 ON 连接条件] ... AND 其他条件;

说明一下:

  • SQL中大写的表示关键字,[ ]中代表的是可选项。

  • 内连接的条件通过连接条件指明,用户的其他筛选条件通过其他条件指明。

显示SMITH的名字和部门名称

给出一张员工表和一张部门表,员工表中的ename代表的是员工的姓名,deptno代表的是员工所在部门的部门号。如下:

MySQL内外连接的具体使用

部门表中的dname代表的是部门名,deptno代表的是部门的部门号。如下:

MySQL内外连接的具体使用

现在要显示SMITH的名字和其所在部门的名称,按照复合查询的做法就是,取员工表和部门表的笛卡尔积,在where子句中指明筛选条件为员工的部门号等于部门的部门号,筛选出每个员工匹配的部门信息,并指明员工姓名为SMITH,筛选出SMITH的信息和其所在部门的信息。如下:

MySQL内外连接的具体使用

实际上述多表查询的方式本质就是内连接,用标准的内连接SQL编写:

  • 将员工表和部门号放在from子句中并通过inner join关键字隔开。

  • 在on子句后指明内连接的条件为员工的部门号等于部门的部门号,保证筛选出来的数据是有意义的。

  • 在and之后指明筛选条件为员工的姓名为SMITH。

这样筛选出来的结果和多表查询筛选出来的结果是一样的,只不过是写法有一点不同而已。如下:

MySQL内外连接的具体使用

外连接

外连接分为左外连接和右外连接。

左外连接

左外连接

左外连接的SQL如下:

SELECT ... FROM t1 LEFT JOIN t2 ON 连接条件 [LEFT JOIN t3 ON 连接条件] ... AND 其他条件;

说明一下:

SQL中大写的表示关键字,[ ]中代表的是可选项。左外连接的条件通过连接条件指明,用户的其他筛选条件通过其他条件指明。

查询所有学生的成绩,就算这个学生没有成绩,也要将学生的个人信息显示出来

给出一张学生表和一张成绩表,学生表中的name代表的是学生的姓名,id代表的是学生的学号。如下:

MySQL内外连接的具体使用

成绩表中的id代表的是考试学生的学号,score代表的是学生的成绩。如下:

MySQL内外连接的具体使用

现在要显示所有学生的成绩,如果直接使用内连接将学生表和成绩表连接起来,然后筛选出学生学号等于考试学生学号的记录,那么只能筛选出有考试成绩的学生信息。如下:

MySQL内外连接的具体使用

而题目要求将没有成绩的学生的个人信息也要显示出来,也就是学生表当中的内容需要完全被显示出来。如果在连接学生表和成绩表时将学生表放在左侧,那么就可以使用左外连接,这时如果左侧表中的某条记录根据连接条件没有找到匹配的右侧表中的记录,就会直接显示左侧表中的记录信息,而其对应的右侧表中的列信息将会用NULL值进行填充。如下:

MySQL内外连接的具体使用

右外连接

右外连接

右外连接的SQL如下:

SELECT ... FROM t1 RIGHT JOIN t2 ON 连接条件 [RIGHT JOIN t3 ON 连接条件] ... AND 其他条件;

说明一下:

  • SQL中大写的表示关键字,[ ]中代表的是可选项。

  • 左外连接的条件通过连接条件指明,用户的其他筛选条件通过其他条件指明。

查询所有的成绩,就算这个成绩没有学生与它对应,也要将成绩信息显示出来

题目要求将没有学生与它对应的成绩信息也要显示出来,也就是成绩表当中的内容需要完全被显示出来。如果在连接学生表和成绩表时将成绩表放在右侧,那么就可以使用右外连接,这时如果右侧表中的某条记录根据连接条件没有找到匹配的左侧表中的记录,就会直接显示右侧表中的记录信息,而其对应的左侧表中的信息将会用NULL值进行填充。如下:

MySQL内外连接的具体使用

简单案例

列出部门名称和这些部门的员工信息,同时列出没有员工的部门

由于题目要求同时列出部门名和员工信息,因此需要将部门表和员工表连接起来,连接条件就是部门的部门号要等于员工所在的部门号。如果直接使用内连接进行查询,那么将会显示出所有满足连接条件的记录。如下:

MySQL内外连接的具体使用

而题目要求同时列出没有员工的部门,也就是部门表当中的内容需要完全被显示出来,如果在连接部门表和员工表时将部门表放在左侧,那么就可以使用左外连接。如下:

MySQL内外连接的具体使用

当然,如果要使用右外连接,那么可以在连接部门表和员工表时将部门表放在右侧。如下:

MySQL内外连接的具体使用

来源:https://blog.csdn.net/chenlong_cxy/article/details/128653907

标签:MySQL,内外连接
0
投稿

猜你喜欢

  • python编程开发之textwrap文本样式处理技巧

    2022-03-20 18:48:26
  • 用python写一个福字(附完整代码)

    2022-10-18 12:37:40
  • MySQL中用通用查询日志找出查询次数最多的语句的教程

    2024-01-13 23:18:00
  • 详解JavaScript中的作用域链与闭包

    2024-04-22 13:07:00
  • Python3利用Qt5实现简易的五子棋游戏

    2022-03-31 20:39:12
  • 浅谈django的render函数的参数问题

    2022-07-10 18:39:20
  • python爬取天气数据的实例详解

    2022-08-26 22:28:46
  • PHP组合模式Composite Pattern优点与实现过程

    2023-05-29 02:10:44
  • 创建IE各版本专属CSS方法

    2007-09-27 12:16:00
  • python os用法总结

    2021-03-16 19:30:16
  • Django 后台获取文件列表 InMemoryUploadedFile的例子

    2021-09-25 11:19:38
  • python抓取网页中链接的静态图片

    2023-04-17 04:27:27
  • Python利用物理引擎Pymunk编写一个解压小游戏

    2022-03-08 16:15:45
  • 亲自教你使用 ChatGPT 编写 SQL JOIN 查询示例

    2024-01-14 18:54:01
  • PHP三层结构(上) 简单三层结构

    2023-06-20 06:36:07
  • Python编程之event对象的用法实例分析

    2023-02-19 09:29:50
  • SQL Server 分页查询通用存储过程(只做分页查询用)

    2024-01-12 20:10:11
  • 解决Navicat无法连接 VMware中Centos系统中的 MySQL服务器的问题

    2024-01-16 03:12:17
  • 对Python+opencv将图片生成视频的实例详解

    2022-01-03 08:42:16
  • 详解如何使用vue-cli脚手架搭建Vue.js项目

    2023-07-02 17:05:19
  • asp之家 网络编程 m.aspxhome.com