• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

MySQL多表连接查询详解

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

多表连接查询

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

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

内连接

首先准备两张表

学生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子句中的子查询:子查询返回的是一张虚拟的表,主查询从该查询从临时表查询出满足的条件

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注极客世界的更多内容!


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Win10配置redis服务实现过程详解发布时间:2022-02-10
下一篇:
Redis连接超时异常的处理方法发布时间:2022-02-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap