MySQL内外连接

MySQL内外连接

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

内连接

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

语法:

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

​ 就是使用inner join table_2 on someting代替了原来的条件

外连接

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

左外连接

  • 使用左外连接,就是说左边的内容会被完全显示,但是右边的如果有匹配的就显示,如果没有匹配的就显示为NULL

语法:

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

eg:

sql 复制代码
-- 建两张表
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);

-- 查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来
-- 当左边表和右边表没有匹配时,也会显示左边表的数据
select * from stu left join exam on stu.id=exam.id; 

右外连接

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

eg:

sql 复制代码
-- 对stu表和exam表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来
select * from stu right join exam on stu.id=exam.id;

​ 其实右连接也可以使用左连接来实现,就是要换一下两个表的位置即可

相关推荐
倔强的石头1062 小时前
场景化落地指南——金仓时序数据库在关键行业的应用实践
数据库·时序数据库·kingbase
xj7573065332 小时前
《精通Django》 第7章 高级视图和URL配置
数据库·django·sqlite
海棠AI实验室2 小时前
第2篇:本地目录与资产标准(把“素材—文案—对话—上架”变成可追溯的生产线)
数据库·资产
数据知道2 小时前
在PostgreSQL中并发保存上亿个图片链接和图片md5的对应关系,如何做最合适?
数据库·postgresql
麦麦鸡腿堡2 小时前
MySQL_合计/统计函数
数据库·mysql
GIS之路2 小时前
ArcGIS Pro 添加底图的方式
前端·数据库·python·arcgis·信息可视化
alonewolf_992 小时前
深入理解Redis线程模型:单线程神话与原子性实战
数据库·redis·缓存·分布式架构
五阿哥永琪2 小时前
MySQL面试题 事务实现全解析:Undo Log、Redo Log、锁与 MVCC 协同机制详解
数据库·mysql
txinyu的博客2 小时前
MySQL 学过但是全忘了?15min帮你快速复习
数据库·mysql
数据知道2 小时前
如何使用 httpx + SQLAlchemy 异步高效写入上亿级图片链接与MD5到 PostgreSQL
数据库·postgresql·httpx