顯示來自多個表的資料——JOIN

brj880719發表於2017-09-26

表關係簡介


一、語法

  1. SELECT 欄位列表
  2.   FROM TABLE1
  3. [CROSS JOIN TABLE2 ] |
  4. [NATURAL JOIN TABLE2 ] |
  5.  [JOIN TABLE2 USING (欄位名) ] |
  6.  [JOIN TABLE2 ON (TABLE.COLUMN_NAME = TABLE2.COLUMN_NAME) ] |
  7. [(LEFT | RIGHT | FULL OUT) JOIN TABLE2 ON (TABLE1.COLUMN_NAME = TABLE2.COLUMN_NAME) ];

二、自然連線

1、USING
  如果不希望參照被連線表的所有同名列進行等值連線,自然連線將無法滿足要求,可以在連線時使用USING子句來設定用於等值連線的列(參照列)名。
不允許在參照列上使用表名或者別名作為字首
  1. --99語法
  2. SELECT EMPNO, ENAME, SAL, EMP.DEPTNO, DNAME
  3.   FROM EMP
  4.   JOIN DEPT
  5.  USING (DEPTNO);
  6.  
  7.  --92語法
  8. SELECT EMPNO, ENAME, SAL, EMP.DEPTNO, DNAME
  9.   FROM EMP, DEPT
  10.  WHERE EMP.DEPTNO = DEPT.DEPTNO;
2、ON
  如果要參照非同名的列進行等值連線,或想設定任意的連線條件,可以使用On子句
  1. SELECT EMPNO, ENAME, SAL, EMP.DEPTNO, DNAME
  2.   FROM EMP
  3.   JOIN DEPT
  4.     ON (EMP.DEPTNO = DEPT.DEPTNO);

三、自連線

  自己和自己做連結

  1. --99語法
  2. SELECT WORKER.LAST_NAME EMP, MANAGER.LAST_NAME MGR
  3.   FROM EMPLOYEES WORKER
  4.   JOIN EMPLOYEES MANAGER
  5.     ON (WORKER.MANAGER_ID = MANAGER.EMPLOYEE_ID);
  6.     
  7. --92語法
  8. SELECT WORKER.LAST_NAME EMP, MANAGER.LAST_NAME MGR
  9.   FROM EMPLOYEES WORKER, EMPLOYEES MANAGER
  10.  WHERE WORKER.MANAGER_ID = MANAGER.EMPLOYEE_ID;

四、非等值連線

  1. --99語法
  2. SELECT E.LAST_NAME, E.SALARY, J.GRADE_LEVEL
  3.   FROM EMPLOYEES E
  4.   JOIN JOB_GRADES J
  5.     ON E.SALARY BETWEEN J.LOWEST_SAL AND J.HIGHEST_SAL;
  6.     
  7. --92語法
  8. SELECT E.LAST_NAME, E.SALARY, J.GRADE_LEVEL
  9.   FROM EMPLOYEES E, JOB_GRADES J
  10.  WHERE E.SALARY BETWEEN J.LOWEST_SAL AND J.HIGHEST_SAL;

五、INNER|OUTER 連線

1、INNER 連線
  兩個表連線,只返回匹配的行,被稱為內連線。
  1. --查詢所有員工以及其部門名字
  2. --99語法
  3. SELECT LAST_NAME, DEPARTMENT_NAME
  4.   FROM EMPLOYEES E
  5.  INNER JOIN DEPARTMENTS D
  6.     ON E.DEPARTMENT_ID = D.DEPARTMENT_ID;

  7. --92語法
  8. SELECT LAST_NAME, DEPARTMENT_NAME
  9.   FROM EMPLOYEES E, DEPARTMENTS D
  10.  WHERE E.DEPARTMENT_ID = D.DEPARTMENT_ID;
2、LEFT OUTER | RIGHT OUTER 連線
  兩個表在連線過程中除了返回滿足連線條件的行以外還返回左(或右)表中不滿足條件的行,這種連線稱為左(或右)外連線。
  1. --哪些部門沒有員工,看出部門名字
  2. --99語法
  3. SELECT DEPARTMENT_NAME
  4.   FROM EMPLOYEES E
  5.  RIGHT JOIN DEPARTMENTS D
  6.     ON E.DEPARTMENT_ID = D.DEPARTMENT_ID
  7.  WHERE LAST_NAME IS NULL;

  8. --92語法
  9. SELECT DEPARTMENT_NAME
  10.   FROM EMPLOYEES E, DEPARTMENTS D
  11.  WHERE E.DEPARTMENT_ID(+) = D.DEPARTMENT_ID
  12.    AND LAST_NAME IS NULL;
3、FULL OUTER 連線
  兩個表在連線過程中除了返回滿足連線條件的行以外還返回兩個表中不滿足條件的行,這種連線稱為全外聯接。
  1. --99
  2. SELECT E.LAST_NAME, D.DEPARTMENT_ID, D.DEPARTMENT_NAME
  3.   FROM EMPLOYEES E
  4.   FULL OUTER JOIN DEPARTMENTS D
  5.     ON E.DEPARTMENT_ID = D.DEPARTMENT_ID;

  6. --92
  7. SELECT E.LAST_NAME, D.DEPARTMENT_ID, D.DEPARTMENT_NAME
  8.   FROM EMPLOYEES E, DEPARTMENTS D
  9.     ON E.DEPARTMENT_ID(+) = D.DEPARTMENT_ID(+);

六、笛卡爾積

笛卡爾集會在下面條件下產生:

1、連線條件被遺漏
2、連線條件不正確
3、所有表中的所有行互相連線

  1. --99語法
  2. SELECT E.LAST_NAME, D.DEPARTMENT_ID, D.DEPARTMENT_NAME
  3.   FROM EMPLOYEES E
  4.  CROSS JOIN DEPARTMENTS D;

  5. --92語法
  6. SELECT E.LAST_NAME, D.DEPARTMENT_ID, D.DEPARTMENT_NAME
  7.   FROM EMPLOYEES E, DEPARTMENTS D;


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

相關文章