1. 程式人生 > >Oracle多表查詢練習

Oracle多表查詢練習

SQL> --等值連線 SQL> --查詢員工資訊:員工號 姓名 月薪 部門名稱 SQL> set linesize 80 SQL> desc dept  名稱                                      是否為空? 型別  ----------------------------------------- -------- ----------------------------  DEPTNO                                    NOT NULL NUMBER(2)  DNAME                                              VARCHAR2(14)  LOC                                                VARCHAR2(13)

SQL> select e.empno,e.ename,e.sal,d.dname   2  from emp e,dept d   3  where e.deptno=d.deptno;

     EMPNO ENAME      SAL DNAME                                                  ---------- -------- ----- --------------                                               7369 SMITH      800 RESEARCH                                                     7499 ALLEN     1600 SALES                                                        7521 WARD      1250 SALES                                                        7566 JONES     2975 RESEARCH                                                     7654 MARTIN    1250 SALES                                                        7698 BLAKE     2850 SALES                                                        7782 CLARK     2450 ACCOUNTING                                                   7788 SCOTT     3000 RESEARCH                                                     7839 KING      5000 ACCOUNTING                                                   7844 TURNER    1500 SALES                                                        7876 ADAMS     1100 RESEARCH                                              

     EMPNO ENAME      SAL DNAME                                                  ---------- -------- ----- --------------                                               7900 JAMES      950 SALES                                                        7902 FORD      3000 RESEARCH                                                     7934 MILLER    1300 ACCOUNTING                                            

已選擇 14 行。

SQL> -- 不等值連線 SQL> --查詢員工資訊:員工號 姓名 月薪  工資級別 SQL> select * from salgrade;

     GRADE      LOSAL      HISAL                                                 ---------- ---------- ----------                                                          1        700       1200                                                          2       1201       1400                                                          3       1401       2000                                                          4       2001       3000                                                          5       3001       9999                                                

SQL> select e.empno,e.ename,e.sal,s.grade   2  from emp e,salgrade s   3  where e.sal between s.losal and s.hisal;

     EMPNO ENAME      SAL      GRADE                                             ---------- -------- ----- ----------                                                   7369 SMITH      800          1                                                   7900 JAMES      950          1                                                   7876 ADAMS     1100          1                                                   7521 WARD      1250          2                                                   7654 MARTIN    1250          2                                                   7934 MILLER    1300          2                                                   7844 TURNER    1500          3                                                   7499 ALLEN     1600          3                                                   7782 CLARK     2450          4                                                   7698 BLAKE     2850          4                                                   7566 JONES     2975          4                                            

     EMPNO ENAME      SAL      GRADE                                             ---------- -------- ----- ----------                                                   7788 SCOTT     3000          4                                                   7902 FORD      3000          4                                                   7839 KING      5000          5                                            

已選擇 14 行。

SQL> host cls

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 count(*) from emp;

  COUNT(*)                                                                       ----------                                                                               14                                                                      

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> 希望:對於某些不成立的記錄(40號部門),任然希望包含在最後的結果中 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 行。

SQL> spool off