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;
相关推荐
Q741_1475 分钟前
每日一题 力扣 3655. 区间乘法查询后的异或 II 模拟 分治 乘法差分法 快速幂 C++ 题解
c++·算法·leetcode·模拟·快速幂·分治·差分法
亚空间仓鼠6 分钟前
OpenEuler系统常用服务(五)
linux·运维·服务器·网络
夏乌_Wx10 分钟前
剑指offer | 2.4数据结构相关题目
数据结构·c++·算法·剑指offer·c/c++
米啦啦.12 分钟前
C+类的友元与静态成员函数,类模板
c++·友元·类模板
超绝振刀怪17 分钟前
【C++可变模板参数】
开发语言·c++·可变模板参数
刘~浪地球22 分钟前
Redis 从入门到精通(十三):哨兵与集群
数据库·redis·缓存
Java开发追求者28 分钟前
windows卸载mysql教程
mysql·mysql卸载
dyyshb1 小时前
PostgreSQL 终极兜底方案
数据库·postgresql
AI成长日志1 小时前
【AI原生开发实战】1.2 传统开发 vs AI原生开发:思维转变与架构差异
服务器·架构·ai-native
minji...1 小时前
Linux 线程同步与互斥(二) 线程同步,条件变量,pthread_cond_init/wait/signal/broadcast
linux·运维·开发语言·jvm·数据结构·c++