1. 程式人生 > >外連接、內連接

外連接、內連接

prior arch div war ear ica manager for per

SQL> --外連接
SQL> --按部門統計員工人數:部門號 部門名稱 人數
SQL> select d.deptno 部門號,d.dname 部門名稱,count(e.empno) 人數
  2  from emp e,dept d
  3  where e.deptno=d.deptno
  4  group by d.deptno,d.dname;

    部門號 部門名稱             人數                                            
---------- -------------- ----------                                            
10 ACCOUNTING 3 20 RESEARCH 5 30 SALES 6 SQL> select * from dept; DEPTNO DNAME LOC
---------- -------------- ------------- 10 ACCOUNTING NEW YORK 20 RESEARCH DALLAS 30 SALES CHICAGO
40 OPERATIONS BOSTON SQL> select * from emp where deptno=40; 未選定行 SQL> /* SQL> 希望: 對於某些不成立的記錄,任然希望包含在最後的結果中 SQL> 左外連接:當where e.deptno=d.deptno不成立的時候,等號左邊的表任然被包含 SQL> 寫法:where e.deptno=d.deptno(+) SQL> 右外連接:當where e.deptno=d.deptno不成立的時候,等號右邊的表任然被包含 SQL> 寫法: where e.deptno(+)=d.deptno SQL> */ SQL> select d.deptno 部門號,d.dname 部門名稱,count(e.empno) 人數 2 from emp e,dept d 3 where e.deptno(+)=d.deptno 4 group by d.deptno,d.dname; 部門號 部門名稱 人數 ---------- -------------- ---------- 10 ACCOUNTING 3 40 OPERATIONS 0 20 RESEARCH 5 30 SALES 6 SQL> host cls SQL> --自連接 SQL> --查詢員工信息:員工姓名 老板姓名 SQL> set linesize 200 SQL> select * from emp; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ---------- ---------- ---------- 7369 SMITH CLERK 7902 17-12月-80 800 20 7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30 7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30 7566 JONES MANAGER 7839 02-4月 -81 2975 20 7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30 7698 BLAKE MANAGER 7839 01-5月 -81 2850 30 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7788 SCOTT ANALYST 7566 19-4月 -87 3000 20 7839 KING PRESIDENT 17-11月-81 5000 10 7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30 7876 ADAMS CLERK 7788 23-5月 -87 1100 20 EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ---------- ---------- ---------- 7900 JAMES CLERK 7698 03-12月-81 950 30 7902 FORD ANALYST 7566 03-12月-81 3000 20 7934 MILLER CLERK 7782 23-1月 -82 1300 10 已選擇 14 行。 SQL> --自連接: 通過表的別名,將同一張表視為多張表 SQL> select e.ename 員工姓名,b.ename 老板姓名 2 from emp e,emp b 3 where e.mgr=b.empno; 員工姓名 老板姓名 ---------- ---------- FORD JONES SCOTT JONES JAMES BLAKE TURNER BLAKE MARTIN BLAKE WARD BLAKE ALLEN BLAKE MILLER CLARK ADAMS SCOTT CLARK KING BLAKE KING 員工姓名 老板姓名 ---------- ---------- JONES KING SMITH FORD 已選擇 13 行。 SQL> select count(*) 2 from emp e, emp b; COUNT(*) ---------- 196 SQL> --自連接不適合操作大表 SQL> --層次查詢 SQL> select level,empno,ename,mgr 2 from emp 3 connect by prior empno=mgr 4 start with mgr is null 5 order by 1; LEVEL EMPNO ENAME MGR ---------- ---------- ---------- ---------- 1 7839 KING 2 7566 JONES 7839 2 7698 BLAKE 7839 2 7782 CLARK 7839 3 7902 FORD 7566 3 7521 WARD 7698 3 7900 JAMES 7698 3 7934 MILLER 7782 3 7499 ALLEN 7698 3 7788 SCOTT 7566 3 7654 MARTIN 7698 LEVEL EMPNO ENAME MGR ---------- ---------- ---------- ---------- 3 7844 TURNER 7698 4 7876 ADAMS 7788 4 7369 SMITH 7902 已選擇 14 行。

外連接、內連接