SQL复习—多表查询
引入
将下面三条sql合成一条? ( 连接三张表 )
使用多表连接:
SELECT city
FROM employees e
JOIN departments d
ON e.department_id = d.department_id
JOIN locations l
ON d.location_id = l.location_id
WHERE e.last_name = 'Abel';
==多表连接时,如果查询语句中出现了 多张表中都存在的字段,需要重叠的字段所属的表名==
==从sql优化角度考虑,建议在多表查询中,每个字段都指明其所在的表名,这样数据量较大时,效率较高==
内连接
合并具有同一列的两张以上的表的行,就是取几张表的交集 (结果集中不包含一张表与另一张表不匹配的行)
两张表
SELECT e.employee_id, e.last_name, e.department_id,
d.department_id, d.location_id
FROM employees e JOIN departments d
ON (e.department_id = d.department_id);
两张以上的表
SELECT employee_id, city, department_name
FROM employees e
JOIN departments d
ON d.department_id = e.department_id
JOIN locations l
ON d.location_id = l.location_id;
外连接
合并具有同一列的两张以上的表的行,结果集中除了两张的表匹配的行,还查询到了 左表 或 右表中不匹配的行
- 左外连接
除了返回满足连接条件的行,还返回了 左表中不满足来连接条件的行
SELECT e.last_name, e.department_id, d.department_name
FROM employees e
LEFT OUTER JOIN departments d
ON (e.department_id = d.department_id) ;
- 右外连接
除了返回满足连接条件的行,还返回了 左表中不满足来连接条件的行
SELECT e.last_name, e.department_id, d.department_name
FROM employees e
RIGHT OUTER JOIN departments d
ON (e.department_id = d.department_id) ;
UNION关键字
合并查询结果 利用UNION关键字,可以给出多条SELECT语句,并将它们的结果组合成单个结果集。合并 时,两个表对应的列数和数据类型必须相同,并且相互对应。各个SELECT语句之间使用UNION或UNION ALL关键字分隔
==UNION:自动去重==
==UNION [ALL]: 不去重==
注意:执行UNION ALL语句时所需要的资源比UNION语句少。如果明确知道合并数据后的结果数据 不存在重复数据,或者不需要去除重复的数据,则尽量使用UNION ALL语句,以提高数据查询的效 率