简述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 |
|
卢森堡 |