SQLserver数据库多表连接查询之外连接
需要创建数据库,数据表可以点击右方链接去下载:sql脚本下载
外连接一共分为
1.左连接
u左连接
左外连接的结果集包括左表的所有行,而不仅仅是连接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。
【例】查询学生姓名、性别、学校名、学校编号。
select stuName,stuSex, schName, schoolInfo.schId, from schoolInfo left join stuInfo on stuInfo.schId= schoolInfo.schId
2.右连接
u右连接
右外连接是左向外连接的反向连接,将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。
【例】查询学生姓名、性别、学校名、学校编号。
select stuName,stuSex, schName, schoolInfo.schId, from stuInfo right join schoolInfo on stuInfo.schId= schoolInfo.schId
3.全连接
u全连接
全连接返回左表和右表中的所有行,当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
【例】查询学生姓名、性别、学校名、学校编号。
select stuName,stuSex, schName, schoolInfo.schId, from stuInfo full join schoolInfo on stuInfo.schId= schoolInfo.schId
外连接基本语法:
分析
inner join会丢失左右表中无法按照连接条件连接的行。还可使用left join(左连接,确保左表不丢失行,没连接上右表的行对应的右边列全部呈现空值)、right join(右连接,与左连接相反)、 、full outer join(全连接,左右表都不丢失行) cross join(交叉连接, 相当于笛卡尔积连接,不能使用on附带连接条件)。
基本语法
select 列名1,列名2… from 表1 left/right/full join 表2 on join_condition
想看更多关于sql教程可以点击下方文字链接:
sql数据库如何实现单表分组查询
© 版权声明
文章版权归作者所有,未经允许请勿转载。
版权声明:
1、IT大王遵守相关法律法规,由于本站资源全部来源于网络程序/投稿,故资源量太大无法一一准确核实资源侵权的真实性;
2、出于传递信息之目的,故IT大王可能会误刊发损害或影响您的合法权益,请您积极与我们联系处理(所有内容不代表本站观点与立场);
3、因时间、精力有限,我们无法一一核实每一条消息的真实性,但我们会在发布之前尽最大努力来核实这些信息;
4、无论出于何种目的要求本站删除内容,您均需要提供根据国家版权局发布的示范格式
《要求删除或断开链接侵权网络内容的通知》:https://itdw.cn/ziliao/sfgs.pdf,
国家知识产权局《要求删除或断开链接侵权网络内容的通知》填写说明: http://www.ncac.gov.cn/chinacopyright/contents/12227/342400.shtml
未按照国家知识产权局格式通知一律不予处理;请按照此通知格式填写发至本站的邮箱 wl6@163.com
1、IT大王遵守相关法律法规,由于本站资源全部来源于网络程序/投稿,故资源量太大无法一一准确核实资源侵权的真实性;
2、出于传递信息之目的,故IT大王可能会误刊发损害或影响您的合法权益,请您积极与我们联系处理(所有内容不代表本站观点与立场);
3、因时间、精力有限,我们无法一一核实每一条消息的真实性,但我们会在发布之前尽最大努力来核实这些信息;
4、无论出于何种目的要求本站删除内容,您均需要提供根据国家版权局发布的示范格式
《要求删除或断开链接侵权网络内容的通知》:https://itdw.cn/ziliao/sfgs.pdf,
国家知识产权局《要求删除或断开链接侵权网络内容的通知》填写说明: http://www.ncac.gov.cn/chinacopyright/contents/12227/342400.shtml
未按照国家知识产权局格式通知一律不予处理;请按照此通知格式填写发至本站的邮箱 wl6@163.com