sql语句中左外连接、右外连接、内连接是什么
小编给大家分享一下sql语句中左外连接、右外连接、内连接是什么,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
以下的代码演示均基于name表和country表展开。
name表
country表
注 :
1)b表A_ID与a表a_id 存在关系
2)连接查询是要使用关联条件去除不匹配数据否则会出现笛卡尔积
1) 内连接
语法:select要查询的字段from表名1innerjoin表名2on表1.字段=表2.字段;innerjoin可简写为逗号,内连接特点:只会保留完全符合on后条件的数据应用场景:如果两张表有外键关系可以使用内链接,因为通过内链接每一条只能返回单条记录
select*fromnameninnerjoincountryconn.id=c.N_ID;id name id country N_ID 1西施1春秋时期越国人12杨玉环2唐代蒲州永乐人23貂蝉3东汉末年山西忻州人34王昭君4西汉时期南郡秭归人4
2)左外连接
语法:select要查询的字段from表1leftouterjoin表2on表1.字段=表2.字段;outer可省略左外连接特点:以左表为主,会保留左表中不符合on后条件的数据应用场景:只有部分记录可以从表2中查到,但表1想要显示所有记录,就可以和表2通过左外连接查询。
select*fromnamenleftjoincountryconn.id=c.N_ID;id name id country N_ID 1西施1春秋时期越国人12杨玉环2唐代蒲州永乐人23貂蝉3东汉末年山西忻州人34王昭君4西汉时期南郡秭归人45赵飞燕nullnullnull
3) 右外连接
语法:select*from表1rightouterjoin表2on表1.字段=表2.字段;outer可省略右外连接特点:以右表为主,会保留右表中不符合on后条件的数据应用场景:和左外连接相反只有部分记录可以从表1中查询到,但表2想要显示所有记录,就可以和表1通过右外连接查询。
select*fromnamenrightjoincountryconn.id=c.N_ID;id name id country N_ID 1西施1春秋时期越国人12杨玉环2唐代蒲州永乐人23貂蝉3东汉末年山西忻州人34王昭君4西汉时期南郡秭归人4nullnull5战国时期6
4) 完全链接
语法:select*from表1fulljoin表2on表1.字段=表2.字段;完全连接特点:会保留表1和表2的全部数据
select*fromnamenfulljoincountryconn.id=c.N_ID;id name id country N_ID 1西施1春秋时期越国人12杨玉环2唐代蒲州永乐人23貂蝉3东汉末年山西忻州人34王昭君4西汉时期南郡秭归人45赵飞燕nullnullnullnullnull5战国时期6
注意:该语法在MySql中不适
看完了这篇文章,相信你对“sql语句中左外连接、右外连接、内连接是什么”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。