MySQL多表连接查询 内连接 外连接 子查询

多表连接查询

表与表之间的连接分为内连接外连接

  • 内连接:仅选出两张表互相匹配的记录
  • 外连接:既包括两张表匹配的记录,也包括不匹配的记录,同时外连接又分为左外连接(左连接)和右外连接(右连接

内连接

首先准备两张表
学生student表
在这里插入图片描述

分数score表
在这里插入图片描述

内连接:在每个表中找出符合条件的共有记录
查询student表中的学生姓名和分数

第一种写法:只使用where

select a.s_name, b.s_score from student a,score b where a.s_id = b.s_id;

第二种写法:join … on…

select a.s_name, b.s_score from student a join score b on a.s_id = b.s_id

第三种写法:inner join … on…

select a.s_name, b.s_score from student a inner join score b on a.s_id = b.s_id

在这里插入图片描述

左连接

左连接:根据左表的记录,在被连接的右表中找出符合条件的记录与之匹配,如果找不到与左表匹配的,用null表示

第一种写法:left join … on …

select a.s_name,b.s_score from student a left join score b on a.s_id = b.s_id

第二种写法:left outer join … on …

select a.s_name,b.s_score from student a left outer join score b on a.s_id = b.s_id

在这里插入图片描述

右连接

**右连接:**根据右表的记录,在被连接的左表中找出符合条件的记录与之匹配,如果找不到匹配的,用null表示

第一种写法:right join … on …

select a.s_name,b.s_score from student a right join score b on a.s_id = b.s_id;

第二种写法:right outer join … on …

select a.s_name,b.s_score from student a right outer join score b on a.s_id = b.s_id;

在这里插入图片描述

子查询

子查询:是多表连接查询的一种实现方式,在一个select语句的from子句或where子句中嵌套了另一个select语句,外层的select查询语句成为主查询,换句话将就是WHERE或FORM中的查询语句称为子查询

WHERE子句中的子查询:子查询返回的值作为主查询的查询条件
FROM子句中的子查询:子查询返回的是一张虚拟的表,主查询从该查询从临时表查询出满足的条件

  • 10
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值