MySQL内外连接

目录

1.内连接

2.外连接

[2.1 左外连接](#2.1 左外连接)

[2.2 右外连接](#2.2 右外连接)


在观看本章之前,请确保有复合查询的基础,若没有,建议移转到MySQL复合查询

1.内连接

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

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

eg:显示SMITH的名字和部门名称

前置工作:

创建一个雇员信息表(来自 oracle 9i 的经典测试表)

EMP 员工表

DEPT 部门表

SALGRADE 工资等级表

复合查询的写法:

cpp 复制代码
mysql> select ename,dname from emp,dept where emp.deptno=dept.deptno 
and ename='SMITH';
+-------+----------+
| ename | dname    |
+-------+----------+
| SMITH | RESEARCH |
+-------+----------+

内连接的写法

cpp 复制代码
mysql> select ename,dname from emp inner join dept on emp.deptno=dept.deptno 
and ename='SMITH';
+-------+----------+
| ename | dname    |
+-------+----------+
| SMITH | RESEARCH |
+-------+----------+

2.外连接

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

2.1 左外连接

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

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

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

cpp 复制代码
-- 建两张表
create table stu (id int, name varchar(30)); -- 学生表
insert into stu values(1,'jack'),(2,'tom'),(3,'kity'),(4,'nono');
create table exam (id int, grade int); -- 成绩表
insert into exam values(1, 56),(2,76),(11, 8);
cpp 复制代码
-- 当左边表和右边表没有匹配时,也会显示左边表的数据
mysql> select * from stu left join exam on stu.id=exam.id;
+------+------+------+-------+
| id   | name | id   | grade |
+------+------+------+-------+
|    1 | jack |    1 |    56 |
|    2 | tom  |    2 |    76 |
|    3 | kity | NULL |  NULL |
|    4 | nono | NULL |  NULL |
+------+------+------+-------+

2.2 右外连接

如果联合查询,右侧的表完全显示我们就说是右外连接。(其实把左右表的顺序一换,就可以使用左外连接)

语法:

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

这里和左外连接差不多,大家可以自行尝试

相关推荐
jieyucx5 分钟前
SQL 查询终极高阶通鉴:从零基础拆解到工业级多表联查、窗口函数与索引优化
数据库·sql
ai_coder_ai1 小时前
论 NoSQL 数据库技术及其应用
数据库·nosql
AOwhisky2 小时前
Redis 学习笔记(第一期):概述、安装配置与核心理论
运维·数据库·redis·笔记·学习·云计算
ytttr8732 小时前
C# 定时数据库备份工具
开发语言·数据库·c#
睡不醒男孩0308232 小时前
自建 Prometheus+Grafana 与 CLUP 深度监控 PG 集群有什么区别?
数据库·oracle
就叫_这个吧3 小时前
IDEA Mybatis xml文件,实现sql语句联想,自动填入补充
xml·mysql·intellij-idea·mybatis
AOwhisky3 小时前
Redis 学习笔记(第四期):高可用与集群(哨兵 + Cluster + 容器化)
linux·运维·数据库·redis·笔记·学习·缓存
猫猫聚会Ing3 小时前
数据库设计 Prompt 提示词 - 构建与迭代
数据库
上海云盾-小余3 小时前
源站隐藏实战:规避裸 IP 被直接攻击的完整方案
数据库·网络协议·tcp/ip
微学AI4 小时前
时序大模型 TimechoAI 赋能工业时序数据底层技术优势与实操
数据库·大模型·时序大模型