MySQL 表的内外连接

个人主页:C++忠实粉丝**
欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 C++忠实粉丝 原创**

MySQL 表的内外连接

收录于专栏[MySQL]
本专栏旨在分享学习MySQL的一点学习笔记,欢迎大家在评论区交流讨论💌

目录

内连接

外连接

左外连接

右外连接


表的连接分为内连和外连

内连接

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

语法:

sql 复制代码
select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;

案例:显示SMITH的名字和部门名称

sql 复制代码
-- 之前的写法
select ename,dname from emp,dept where emp.deptno=dept.deptno and ename='SMITH';
sql 复制代码
-- 用标准的内连接写法
select ename,dname from emp inner join dept on emp.deptno=dept.deptno and ename='SMITH';

外连接

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

左外连接

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

语法:

sql 复制代码
select 字段名 from 表名1 left join 表名2 on 连接条件

案例:

建立两张表:

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

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

右外连接

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

语法:

sql 复制代码
select 字段 from 表名1 right join 表名2 on 连接条件;

案例:

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

案例二:

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

sql 复制代码
方法一:
select d.dname,e.* from dept d left join emp e on d.depton=e.deptno;
方法二:
select d.dname,e.* from emp e right join dept d on d.depton=e.depton;

左连接 的情况下,dept 表中的所有记录都会显示出来,即使 emp 表没有匹配的记录,如果没有匹配的员工信息,则 emp 表的列会显示为 NULL。

右连接 的情况下,dept 表中所有记录都会显示出来。如果 emp 表中没有匹配的记录,则 emp 表的列会显示为 NULL。

相关推荐
likangbinlxa8 分钟前
【Oracle11g SQL详解】UPDATE 和 DELETE 操作的正确使用
数据库·sql
r i c k36 分钟前
数据库系统学习笔记
数据库·笔记·学习
野犬寒鸦1 小时前
从零起步学习JVM || 第一章:类加载器与双亲委派机制模型详解
java·jvm·数据库·后端·学习
IvorySQL2 小时前
PostgreSQL 分区表的 ALTER TABLE 语句执行机制解析
数据库·postgresql·开源
·云扬·2 小时前
MySQL 8.0 Redo Log 归档与禁用实战指南
android·数据库·mysql
IT邦德2 小时前
Oracle 26ai DataGuard 搭建(RAC到单机)
数据库·oracle
惊讶的猫2 小时前
redis分片集群
数据库·redis·缓存·分片集群·海量数据存储·高并发写
不爱缺氧i2 小时前
完全卸载MariaDB
数据库·mariadb
纤纡.3 小时前
Linux中SQL 从基础到进阶:五大分类详解与表结构操作(ALTER/DROP)全攻略
linux·数据库·sql
jiunian_cn3 小时前
【Redis】渐进式遍历
数据库·redis·缓存