oracle 串連查詢,oracle串連

來源:互聯網
上載者:User

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可以省略。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.