理解sql语句的内连接、左外连接、右外连接


本文摘自PHP中文网,作者coldplay.xixi,侵删。

推荐( 免费):SQL教程

大家在初学数据库时,对DQL中的连接查询是否有些疑惑,不知道什么时候什么场景下该用那种连接查询?
在这里插入图片描述
不要着急,接下来由我来给大家介绍一下,本人对内连接、左外连接、右外连接的特点和应用场景的理解,供大家参考。

以下的代码演示均基于name表和country表展开。
name表

idname
1西施
2杨玉环
3貂蝉
4王昭君
5赵飞燕

country表

idcountryA_ID
1春秋时期越国人1
2唐代蒲州永乐人2
3东汉末年山西忻州人3
4西汉时期南郡秭归人4
5战国时期6

注 :
1)b表A_ID与a表a_id 存在关系
2)连接查询是要使用关联条件去除不匹配数据否则会出现笛卡尔积

1) 内连接

1

2

3

4

5

6

语法: select  要查询的字段 from 表名1 inner join 表名2 on 表1.字段 = 表2.字段;

    inner join 可简写为 逗号,

内连接特点:

    只会保留完全符合on后条件的数据

应用场景:

    如果两张表有外键关系可以使用内链接,因为通过内链接每一条只能返回单条记录

1

select * from name n inner join country c on n.id = c.N_ID;

idnameidcountryN_ID
1西施1春秋时期越国人1
2杨玉环2唐代蒲州永乐人2
3貂蝉3东汉末年山西忻州人3
4王昭君4西汉时期南郡秭归人4

2)左外连接

1

2

3

4

5

6

语法: select 要查询的字段 from 表1 left outer join 表2 on 表1.字段 = 表2.字段;

    outer 可省略

左外连接特点:

    以左表为主,会保留左表中不符合on后条件的数据

应用场景:

    只有部分记录可以从表2中查到,但表1想要显示所有记录,就可以和表2通过左外连接查询。

1

select * from name n left join country c on n.id=c.N_ID;

idnameidcountryN_ID
1西施1春秋时期越国人1
2杨玉环2唐代蒲州永乐人2
3貂蝉3东汉末年山西忻州人3
4王昭君4西汉时期南郡秭归人4
5赵飞燕nullnullnull

3) 右外连接

1

2

3

4

5

6

7

语法: select * from 表1 right outer join 表2 on 表1.字段 = 表2.字段;

    outer 可省略

右外连接特点:

    以右表为主,会保留右表中不符合on后条件的数据

应用场景:

    和左外连接相反

    只有部分记录可以从表1中查询到,但表2想要显示所有记录, 就可以和表1通过右外连接查询。

1

select * from name n right join country c on n.id=c.N_ID;

idnameidcountryN_ID
1西施1春秋时期越国人1
2杨玉环2唐代蒲州永乐人2
3貂蝉3东汉末年山西忻州人3
4王昭君4西汉时期南郡秭归人4
nullnull5战国时期6

4) 完全链接

1

2

语法: select * from 表1 full join 表2 on 表1.字段 = 表2.字段;完全连接特点:

    会保留表1和表2的全部数据

1

select * from name n full join country c on n.id=c.N_ID;

idnameidcountryN_ID
1西施1春秋时期越国人1
2杨玉环2唐代蒲州永乐人2
3貂蝉3东汉末年山西忻州人3
4王昭君4西汉时期南郡秭归人4
5赵飞燕nullnullnull
nullnull5战国时期6

注意:该语法在MySql中不适用
好的,本人介绍完毕,不知道有没有帮助到各位呢?
如果有什么不对,还请各位指出哦~
在这里插入图片描述

更多相关知识敬请关注sql栏目~

以上就是理解sql语句的内连接、左外连接、右外连接的详细内容,更多请关注木庄网络博客其它文章!

相关阅读 >>

理解sql语句的内连接、左外连接、右外连接

更多相关阅读请进入《左连接特点》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...