【MySQL】表的内连和外连(重点)

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


一、内连接

内连接实际上就是利用 where 子句对两种表形成的笛卡儿积进行筛选,前面学习的查询都是内连接,也是在开发过程中使用的最多的连接查询。

select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;

注意:前面学习的都是内连接。


⚪练习 ------ 显示 SMITH 的名字和部门名称

(1)用前面的写法

(2)用标准的内连接写法

二、外连接

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


1、左外连接

如果联合查询,左侧的表完全显示我们就说是左外连接。

select 字段名 from 表名1 left join 表名2 on 连接条件


⚪练习
  • 建两张表并插入数据
  1. 学生表
  2. 成绩表

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

  • 当左边表和右边表没有匹配时,也会显示左边表的数据

2、右外连接

如果联合查询,右侧的表完全显示我们就说是右外连接。

select 字段 from 表名1 right join 表名2 on 连接条件;


⚪练习
(1)对 stu 表和 exam 表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来

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

a. 方法一

b. 方法二
相关推荐
只说证事16 小时前
会计岗位向管理会计升级,最该补哪些数据分析技能
数据库·数据挖掘·数据分析
a95114164217 小时前
如何加固SQL集群防注入_实施网络层访问控制策略
jvm·数据库·python
2401_8359568117 小时前
mysql处理大量更新场景_InnoDB MVCC与MyISAM对比
jvm·数据库·python
m0_7489203617 小时前
Oracle默认端口被占用如何连接_修改端口号操作教程
jvm·数据库·python
qq_3422958217 小时前
Redis怎样按照距离远近排序展示_通过GEORADIUS的ASC参数进行Geo排序
jvm·数据库·python
2201_7610405917 小时前
C#比较两个二进制文件的差异 C#如何实现一个二进制diff工具
jvm·数据库·python
Polar__Star18 小时前
SQL中如何实现特定顺序的查询:CASE WHEN自定义排序
jvm·数据库·python
一只大袋鼠18 小时前
MyBatis 入门详细实战教程(一):从环境搭建到查询运行
java·开发语言·数据库·mysql·mybatis
u01091476018 小时前
mysql如何配置监听IP_mysql bind-address多地址设置
jvm·数据库·python
java资料站18 小时前
MySQL 8.0.45 完整mysqld_safe启动
数据库·mysql