在SQL Server中已經學習過內聯接(inner join)、外聯接(outer join),外聯接又分為左外聯接(left outer join)和
右外聯接(right outer join)。Oracle中對兩個表或者若干表之間的外聯接用(+)表示。
代碼演示:請查詢出工資大於2000元的員工的姓名,部門,工作,工資。
由於部門名稱在dept中,其他的信息在emp表中,需要內聯接才能完成。
SQL> SELECT e.ENAME,e.JOB,e.SAL,d.DNAME 2 FROM emp e,dept d 3 WHERE e.deptno=d.deptno 4 AND e.SAL>2000;
也可以使用SQL/92標准中的內聯接:
代碼演示:內聯接
SELECT e.ENAME,e.JOB,e.SAL,d.DNAME FROM EMP e INNER JOIN DEPT d ON e.DEPTNO=d.DEPTNO WHERE e.SAL>2000;
這裡INNER JOIN中,關鍵字INNER可以省略。
代碼演示:查詢出每個部門下的員工姓名,工資。Emp表用外鍵deptno引用Dept表中的deptno,
在Dept表中如果有某些部門沒有員工,那麼用內聯接,沒有員工的部門將無法顯示,因此必須以Dept表為基准的外聯接。
SQL> SELECT e.ENAME,e.JOB,e.SAL,d.DNAME 2 FROM EMP e ,DEPT d 3 WHERE e.DEPTNO(+)=d.DEPTNO 4 /
代碼解析:
(+):Oracle專用的聯接符,在條件中出現在左邊指右外聯接,出現在右邊指左外聯接。
也可以使用SQL/92標准的寫法:
代碼演示:外聯接
SELECT e.ENAME,e.JOB,e.SAL,d.DNAME FROM EMP e RIGHT OUTER JOIN DEPT d ON e.DEPTNO=d.DEPTNO;
這裡RIGHT OUTER JOIN中,關鍵字OUTER可以省略。