sql语句中左外连接、右外连接、内连接是什么

小编给大家分享一下sql语句中左外连接、右外连接、内连接是什么,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

站在用户的角度思考问题,与客户深入沟通,找到米东网站设计与米东网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站建设、网站设计、企业官网、英文网站、手机端网站、网站推广、域名注册、虚拟空间、企业邮箱。业务覆盖米东地区。

以下的代码演示均基于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) 内连接

语法:	select  要查询的字段 from 表名1 inner join 表名2 on 表1.字段 = 表2.字段;
	inner join 可简写为 逗号,
内连接特点:
	只会保留完全符合on后条件的数据
应用场景:
	如果两张表有外键关系可以使用内链接,因为通过内链接每一条只能返回单条记录
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)左外连接

语法:	select 要查询的字段 from 表1 left outer join 表2 on 表1.字段 = 表2.字段;
	outer 可省略
左外连接特点:
	以左表为主,会保留左表中不符合on后条件的数据
应用场景:
	只有部分记录可以从表2中查到,但表1想要显示所有记录,就可以和表2通过左外连接查询。
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) 右外连接

语法:	select * from 表1 right outer join 表2 on 表1.字段 = 表2.字段;
	outer 可省略
右外连接特点:
	以右表为主,会保留右表中不符合on后条件的数据
应用场景:
	和左外连接相反
	只有部分记录可以从表1中查询到,但表2想要显示所有记录, 就可以和表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) 完全链接

语法:	select * from 表1 full join 表2 on 表1.字段 = 表2.字段;完全连接特点:
	会保留表1和表2的全部数据
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语句中左外连接、右外连接、内连接是什么
本文链接:https://www.cdcxhl.com/article34/pdcsse.html

成都网站建设公司_创新互联,为您提供服务器托管小程序开发虚拟主机企业建站网站制作静态网站

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都网站建设