多表查詢(xún)的分類(lèi)
/*
角度1:等值連接 vs 非等值連接
角度2:自連接 vs 非自連接
角度3:內(nèi)連接 vs 外連接
*/
7.1 等值連接 vs 非等值連接
非等值連接的例子:
SELECT *
FROM job_grades;
SELECT e.last_name,e.salary,j.grade_level
FROM employees e,job_grades j
where e.salary
between j.lowest_sal
and j.highest_sal
;
WHERE e.salary
>= j.lowest_sal
AND e.salary
<= j.highest_sal
;
7.2 自連接 vs 非自連接
SELECT * FROM employees;
自連接的例子:
練習(xí):查詢(xún)員工id,員工姓名及其管理者的id和姓名
SELECT emp.employee_id,emp.last_name,mgr.employee_id,mgr.last_name
FROM employees emp ,employees mgr
WHERE emp.manager_id
= mgr.employee_id
;
7.3 內(nèi)連接 vs 外連接
內(nèi)連接:合并具有同一列的兩個(gè)以上的表的行, 結(jié)果集中不包含一個(gè)表與另一個(gè)表不匹配的行
SELECT employee_id,department_name
FROM employees e,departments d
WHERE e.department_id
= d.department_id; #只有106條記錄
外連接:合并具有同一列的兩個(gè)以上的表的行, 結(jié)果集中除了包含一個(gè)表與另一個(gè)表匹配的行之外,
還查詢(xún)到了左表 或 右表中不匹配的行。
外連接的分類(lèi):左外連接尤溜、右外連接判莉、滿(mǎn)外連接
左外連接:兩個(gè)表在連接過(guò)程中除了返回滿(mǎn)足連接條件的行以外還返回左表中不滿(mǎn)足條件的行台汇,這種連接稱(chēng)為左外連接衷咽。
右外連接:兩個(gè)表在連接過(guò)程中除了返回滿(mǎn)足連接條件的行以外還返回右表中不滿(mǎn)足條件的行悬嗓,這種連接稱(chēng)為右外連接狞换。
練習(xí):查詢(xún)所有的員工的last_name,department_name信息
SELECT employee_id,department_name
FROM employees e,departments d
WHERE e.department_id
= d.department_id; # 需要使用左外連接
SQL92語(yǔ)法實(shí)現(xiàn)內(nèi)連接:見(jiàn)上避咆,略
SQL92語(yǔ)法實(shí)現(xiàn)外連接:使用 + ----------MySQL不支持SQL92語(yǔ)法中外連接的寫(xiě)法!
不支持:
SELECT employee_id,department_name
FROM employees e,departments d
WHERE e.department_id
= d.department_id(+);
SQL99語(yǔ)法中使用 JOIN ...ON 的方式實(shí)現(xiàn)多表的查詢(xún)修噪。這種方式也能解決外連接的問(wèn)題查库。MySQL是支持此種方式的。
SQL99語(yǔ)法如何實(shí)現(xiàn)多表的查詢(xún)黄琼。
SQL99語(yǔ)法實(shí)現(xiàn)內(nèi)連接:
SELECT last_name,department_name
FROM employees e INNER JOIN departments d
ON e.department_id
= d.department_id
;
SELECT last_name,department_name,city
FROM employees e JOIN departments d
ON e.department_id
= d.department_id
JOIN locations l
ON d.location_id
= l.location_id
;
SQL99語(yǔ)法實(shí)現(xiàn)外連接:
練習(xí):查詢(xún)所有的員工的last_name,department_name信息
左外連接:
SELECT last_name,department_name
FROM employees e LEFT JOIN departments d
ON e.department_id
= d.department_id
;
右外連接:
SELECT last_name,department_name
FROM employees e RIGHT OUTER JOIN departments d
ON e.department_id
= d.department_id
;
滿(mǎn)外連接:mysql不支持FULL OUTER JOIN
SELECT last_name,department_name
FROM employees e FULL OUTER JOIN departments d
ON e.department_id
= d.department_id
;