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;

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

相关推荐
疯狂的挖掘机6 小时前
记一次基于QT的图片操作处理优化思路(包括在图上放大缩小,截图,画线,取值等)
开发语言·数据库·qt
奇树谦8 小时前
Qt | 利用map创建多个线程和定时器
网络·数据库·qt
用户47949283569158 小时前
性能提升 4000%!我是如何解决 运营看板 不能跨库&跨库查询慢这个难题的
数据库·后端·postgresql
电商API&Tina8 小时前
跨境电商 API 对接指南:亚马逊 + 速卖通接口调用全流程
大数据·服务器·数据库·python·算法·json·图搜索算法
robinson19888 小时前
验证崖山数据库标量子查询是否带有CACHE功能
数据库·oracle·cache·自定义函数·崖山·标量子查询
老华带你飞8 小时前
农产品销售管理|基于java + vue农产品销售管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
SelectDB9 小时前
5 倍性能提升,Apache Doris TopN 全局优化详解|Deep Dive
数据库·apache
JIngJaneIL9 小时前
基于springboot + vue房屋租赁管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
陈平安安10 小时前
设计一个秒杀功能
java·数据库·sql
isNotNullX10 小时前
数据处理的流程是什么?如何进行数据预处理?
数据库·数据资产管理·数据处理·企业数字化