志在指尖
用双手敲打未来

SQLserver数据库多表连接查询之外连接

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数据库如何实现单表分组查询

未经允许不得转载:IT技术网站 » SQLserver数据库多表连接查询之外连接
分享到: 更多 (0)

评论 抢沙发

评论前必须登录!

 

志在指尖 用双手敲打未来

登录/注册IT技术大全

热门IT技术

C#基础入门   SQL server数据库   系统SEO学习教程   WordPress小技巧   WordPress插件   脚本与源码下载