左連線和右連線

pentium發表於2007-03-04

SELECT emp_name, dept_name FORM Employee, DepartmentWHERE Employee.emp_deptid(+) = Department.deptid此SQL文使用了右連線,即“(+)”所在位置的另一側為連線的方向,右連線說明等號右側的所有記錄均會被顯示,無論其在左側是否得到匹配,也就是說上例中無論會不會出現某個部門沒有一個員工的情況,這個部門的名字都會在查詢結果中出現。反之:SELECT emp_name, dept_name FORM Employee, DepartmentWHERE Employee.emp_deptid = Department.


左連線和右連線 [@more@]

Oracle PL-SQL 中,左連線和右連線以如下方式來實現 檢視如下語句:

SELECT emp_name, dept_name
FORM Employee, Department
WHERE Employee.emp_deptid( + ) = Department.deptid

SQL 文使用了右連線,即 “(+)” 所在位置的另一側為連線的方向,右連線說明等號右側的所有記錄均會被顯示,無論其在左側是否得到匹配, 也就是說上例中無論會不會出現某個部門沒有一個員工的情況,這個部門的名字都會在查詢結果中出現。 反之:

SELECT emp_name, dept_name
FORM Employee, Department
WHERE Employee.emp_deptid = Department.deptid( + )

則是左連線,無論這個員工有沒有一個能在 Department 表中得到匹配的部門號,這個員工的記錄都會被顯示

另見:

一般的相等連線:
select * from a, b where a.id = b.id;
這個就屬於 內連線

對於 外連線
Oracle中可以使用“(+) ”來表示,9i可以使用LEFT/RIGHT/FULL OUTER JOIN

LEFT OUTER JOIN:左外關聯
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, departments d
WHERE e.department_id=d.department_id(+)
結果為:所有員工及對應部門的記錄,包括沒有對應部門編號department_id的員工記錄。

RIGHT OUTER JOIN:右外關聯
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);
等價於
SELECT e.last_name, e.department_id, d.department_name
FROM employees e, departments d
WHERE e.department_id(+)=d.department_id
結果為:所有員工及對應部門的記錄,包括沒有任何員工的部門記錄。

FULL OUTER JOIN:全外關聯
SELECT e.last_name, e.department_id, d.department_name
FROM employees e
FULL OUTER JOIN departments d
ON (e.department_id = d.department_id);
結果為:所有員工及對應部門的記錄,包括沒有對應部門編號department_id的員工記錄和沒有任何員工的部門記錄。
sybase的左、右外連線:
select a.name,b.name from emp a right join dept b on a.depid = b.id
select a.name,b.name from emp a,dept b where a.depid =* b.id
相當於oracle的
SELECT emp_name, dept_name
FORM Employee, Department
WHERE Employee.emp_deptid( + ) = Department.deptid

下面 4 個查詢是一樣的執行結果,返回資料相同,但執行計劃不同(只有第二個和第 4 個相同) :

SELECT deptno

FROM dept

WHERE deptno NOT IN (SELECT deptno FROM emp) 

(不是很高效率的語句)

SELECT deptno

FROM dept

WHERE NOT EXISTS (SELECT 1 FROM emp WHERE emp.deptno = dept.deptno)

  SELECT deptno FROM dept

MINUS

SELECT deptno FROM emp

  SELECT dept.deptno

FROM dept, emp

WHERE dept.deptno = emp.deptno(+) AND emp.deptno IS NULL

(左連線,左邊的 dept.deptno 都會顯示無論右邊的 emp 裡面有沒有這個 deptno, emp.deptno IS NULL 就表示了選出 dept 裡面 emp 裡面沒有的 deptno


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/14377/viewspace-902520/,如需轉載,請註明出處,否則將追究法律責任。

相關文章