左連線和右連線
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的員工記錄和沒有任何員工的部門記錄。
select a.name,b.name from emp a,dept b where a.depid =* b.id
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/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 左連線,右連線
- Oracle的左連線和右連線Oracle
- 內連線、左連線、右連線
- Oracle左連線,右連線Oracle
- 左連線與右連線
- SQL中的左連線和右連線SQL
- MYSQL語法:左連線、右連線、內連線、全外連線MySql
- pl/sql裡的左連線和右連線符號“+”SQL符號
- mysql 左連線,右連線,內連結,exists等MySql
- SQL的四種連線:內連線 左外連線 右外連線 全連線SQL
- 【SQL】Oracle的內連線、左外連線、右外連線及全外連線SQLOracle
- Oracle左外連線、右外連線、完全外連線以及(+)號用法Oracle
- Oracle 左外連線、右外連線、全外連線小總結Oracle
- mysql INNER JOIN、LEFT JOIN、RIGHT JOIN;內連線(等值連線)、左連線、右連線MySql
- 深入理解SQL的四種連線-左外連線、右外連線、內連線、全連線SQL
- oracle sql內連線_左(右)連線_全外連線_幾種寫法OracleSQL
- sql和hql中join語句區別,以及hibernate中內連線,迫切內連線,左外連線,迫切左外連線,右外連線的區別(合集)...SQL
- 深入淺出SQL之左連線、右連線和全連線SQL
- 內聯,左外聯,右外聯,全連線,交叉連線 的區別
- mysql左外連線MySql
- Oracle內連線、外連線、右外連線、全外連線小總結Oracle
- InfoSet中左外連線
- 連線和半連線
- Socket連線和Http連線HTTP
- 長連線和短連線
- sql 內連線和外連線SQL
- 長連線和短連線的使用
- 連線池和連線數詳解
- http的長連線和短連線HTTP
- LINUX 硬連線和軟連線Linux
- 交叉線和直連線
- 區分socket連線和tcp/ip連線TCP
- 等值連線和自然連線的區別
- 例項解析外連線 內連線 自連線 全連線
- JAVA之長連線、短連線和心跳包Java
- HTTP非持續連線和持續連線HTTP
- scrapy軟連線失效和pip軟連線失效
- HTTP長連線和短連線原理淺析HTTP