oracle 串連查詢,oracle串連
在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.DEPTNOWHERE 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可以省略。