MySQL表得内外连接

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

一、内连接

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

语法:

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

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

二、外连接

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

2.1左外连接

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

语法:

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

案例:

建立学生表:

建立成绩表:

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

2.2右外连接

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

语法:

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

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

连接的应用:列出部门名称和这些部门的员工信息,同时列出没有员工的部门

bash 复制代码
#方法一:
select d.dname, e.* from dept d left join emp e on d.deptno=e.deptno;
#方法二:
select d.dname, e.* from emp e right join dept d on d.deptno=e.deptno;
相关推荐
剩下了什么15 小时前
MySQL JSON_SET() 函数
数据库·mysql·json
山峰哥15 小时前
数据库工程与SQL调优——从索引策略到查询优化的深度实践
数据库·sql·性能优化·编辑器
较劲男子汉15 小时前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
java搬砖工-苤-初心不变15 小时前
MySQL 主从复制配置完全指南:从原理到实践
数据库·mysql
wypywyp16 小时前
8. ubuntu 虚拟机 linux 服务器 TCP/IP 概念辨析
linux·服务器·ubuntu
阿蒙Amon16 小时前
TypeScript学习-第10章:模块与命名空间
学习·ubuntu·typescript
Doro再努力16 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
senijusene16 小时前
Linux软件编程:IO编程,标准IO(1)
linux·运维·服务器
不像程序员的程序媛16 小时前
Nginx日志切分
服务器·前端·nginx
忧郁的橙子.16 小时前
02-本地部署Ollama、Python
linux·运维·服务器