简述SQL中的“外连接”
1、SQL中外连接分为三种:左外连接、右外连接、全外连接。
2、英文书写格式:
左外连接:LEFT OUTER JOIN(LEFT JOIN);
右外连接:RIGHT OUTER JOIN(RIHT JOIN);
全外连接:FULL OUTER JOIN(FULL JOIN)。
3、简记:
左外连接显示“左边全部的”和“右边与左边相同的”;
右外连接显示“右边全部的”和“左边与右边相同的”;
全外连接显示左、右两边全部的。
4、举例:
(1)查询所有球员及对应球队的记录,包括没有对应球队的球员记录?(处于自由状态的球员暂时不归属于任何球队)
(2)查询所有球员及对应球队的记录,包括没有任何球员的球队记录?(假设因战争等原因而不能组建的某国家队,在表中存有球队信息但是没有对应球员名单)
(3)查询所有球员及对应球队的记录,包括没有任何球员的球队记录,并且包括不归属于任何球队的球员的记录?
5、查询语句:
(1)查询所有球员及对应球队的记录,包括没有对应球队的球员记录?
SELECT p.team_id,p.player_name,t.team_name
FROM playerlist p LEFT OUTER JOIN teamlist t ON(p.team_id=t.team_id);
等价于
SELECT p.team_id,p.player_name,t.team_name
FROM playerlist p,teamlist t WHERE p.team_id=t.team_id( );
(2)查询所有球员及对应球队的记录,包括没有任何球员的球队记录?
SELECT p.team_id,p.player_name,t.team_name
FROM playerlist p RIGHT OUTER JOIN teamlist t ON(p.team_id=t.team_id);
等价于
SELECT p.team_id,p.player_name,t.team_name
FROM playerlist p,teamlist t WHERE p.team_id( )=t.team_id;
(3)查询所有球员及对应球队的记录,包括没有任何球员的球队记录,并且包括不归属于任何球队的球员的记录?
SELECT p.team_id,p.player_name,t.team_name
FROM playerlist p FULL OUTER JOIN teamlist t ON(p.team_id=t.team_id);
6、图例
通过图例结合第5点查看SQL语句:
player_list | |
---|---|
team_id | player_name |
00001 | 卡卡 |
00002 | 贝克汉姆 |
00004 | 齐达内 |
team_list | |
---|---|
team_id | team_name |
00001 | 巴西队 |
00003 | 卢旺达 |
00005 | 伊拉克 |
查询所有球员及对应球队的记录,包括没有对应球队的球员记录 | ||
---|---|---|
team_id | player_name | team_name |
00001 | 卡卡 | 巴西队 |
00002 | 贝克汉姆 | |
00004 | 齐达内 |
查询所有球员及对应球队的记录,包括没有任何球员的球队记录 | ||
---|---|---|
team_id | player_name | team_name |
00001 | 卡卡 | 巴西队 |
00003 | 卢旺达 | |
00005 | 卢森堡 |
查询所有球员及对应球队的记录,包括没有任何球员的球队记录,并且包括不归属于任何球队的球员的记录 | ||
---|---|---|
team_id | player_name | team_name |
00001 | 卡卡 | 巴西队 |
00002 | 贝克汉姆 | |
00003 | 卢旺达 | |
00004 | 齐达内 | |
00005 | 卢森堡 |
***********************************************声明************************************************
原创作品,出自 “深蓝的blog” 博客,欢迎转载,转载时请务必注明出处(http://blog.csdn.net/huangyanlong)。
表述有错误之处,请您留言,不胜感激。
*****************************************************************************************************
补充:
等号在( )的左侧,为左外连接,左边表数据全部显示;
等号在( )的右侧,为右外连接,右边表数据全部显示。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/179749.html原文链接:https://javaforall.cn