sql server 表连接
短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
数据库操作中,我们需要的结果可能在两张表甚至多张表中,这时候就需要表连接操作,多表查询中的各个表之间的字段会存在连接,比如主外键关联,可以使用主外键来关联每张表。表连接方式有以下几种:
- JOIN: 如果表中有至少一个匹配,则返回行
- LEFT JOIN(左连接): 即使右表中没有匹配,也从左表返回所有的行
- RIGHT JOIN(右连接): 即使左表中没有匹配,也从右表返回所有的行
- FULL JOIN(全连接): 只要其中一个表中存在匹配,就返回行
下面用两个表演示下上面4种连接方式,两表数据为:
1. JOIN连接:如果表中有至少一个匹配,则返回行
执行SQL语句:
SELECT
stu.ID,
stu.StudentID,
stu.StudentName,
sco.ID,
sco.Score,
sco.StudentID
FROM [BlogDemo].[dbo].[Student] stu
Join [BlogDemo].[dbo].[Score] sco On sco.StudentID=stu.StudentID
结果如下,查询结果集只返回两表匹配StudentID字段相同行。
2.LEFT JOIN(左连接): 即使右表中没有匹配,也从左表返回所有的行
执行SQL语句:
SELECT
stu.ID,
stu.StudentID,
stu.StudentName,
sco.ID,
sco.Score,
sco.StudentID
FROM [BlogDemo].[dbo].[Student] stu
Left Join [BlogDemo].[dbo].[Score] sco On sco.StudentID=stu.StudentID
结果如下,查询结果集只返回右表所有行,左表只返回与右表匹配行。
3. RIGHT JOIN(右连接): 即使左表中没有匹配,也从右表返回所有的行
执行SQL语句:
SELECT
stu.ID,
stu.StudentID,
stu.StudentName,
sco.ID,
sco.Score,
sco.StudentID
FROM [BlogDemo].[dbo].[Student] stu
Right Join [BlogDemo].[dbo].[Score] sco On sco.StudentID=stu.StudentID
结果如下,查询结果集只返回左表所有行,右表只返回与左表匹配行。
4. FULL JOIN(全连接): 只要其中一个表中存在匹配,就返回行
执行SQL语句:
SELECT
stu.ID,
stu.StudentID,
stu.StudentName,
sco.ID,
sco.Score,
sco.StudentID
FROM [BlogDemo].[dbo].[Student] stu
FULL Join [BlogDemo].[dbo].[Score] sco On sco.StudentID=stu.StudentID
结果如下,查询结果集返回两表的所有行。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341