程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle教程 >> Oracle學習(五):多表查詢

Oracle學習(五):多表查詢

編輯:Oracle教程

1.知識點:可以對照下面的錄屏進行閱讀

SQL> --等值連接
SQL> --查詢員工信息: 員工號 姓名 月薪  部門名稱
SQL> select empno,ename,sal,dname
  2  from emp,dept
  3  where emp.deptno=dept.deptno;

SQL> --不等值連接
SQL> --查詢員工信息: 姓名 月薪  工資級別
SQL> select ename,sal,grade
  2  from emp e,salgrade s
  3  where e.sal between s.losal and s.hisal;

SQL> --外連接
SQL> -- 外連接解決的問題:當條件不成立時,任然希望在結果中包含不成立的記錄
SQL> -- 左外連接: where d.deptno=e.deptno 當不成立時,等號左邊代表的表的信息任然被包含
SQL> --         寫法: where d.deptno=e.deptno(+)
SQL> -- 右外連接: where d.deptno=e.deptno 當不成立時,等號右邊代表的表的信息任然被包含
SQL> --         寫法:where d.deptno(+)=e.deptno
SQL> --按部門統計員工人數: 部門號  部門名稱  人數
SQL> --錯誤的列子:沒有員工的部門,沒有顯示
SQL> select d.deptno,d.dname,count(e.empno)
  2  from dept d,emp e
  3  where d.deptno=e.deptno
  4  group by d.deptno,d.dname;
SQL> --上面這個例子改正版:使用了左外連接
SQL> select d.deptno,d.dname,count(e.empno)
  2  from dept d,emp e
  3  where d.deptno=e.deptno(+)
  4  group by d.deptno,d.dname;

SQL> --自連接
SQL> --查詢員工信息:***的老板是***
SQL> select e.ename||'的老板是'||b.ename
  2  from emp e,emp b
  3  where e.mgr=b.empno;
SQL> --核心:利用表的別名,將同一張表視為多張表

SQL> --使用層次查詢的原因:自連接不太適合操作大表
SQL> --層次查詢:對同一張表的前後兩次操作,進行連接
SQL> --層次查詢:遍歷一棵樹
SQL> select level,empno,ename,mgr	--level:偽列,Oracle自動加上的列,在層次查詢中表示節點的深度
  2  from emp
  3  connect by prior empno=mgr	--連接條件:上一次查詢的empno = 下一次查詢的mgr
  4  start with mgr is null	--從根開始遍歷整個樹(在這個例子中,根即為老板號為空)
  5  order by 1;

2.在Sqlplus下實際執行的結果錄屏:

SQL> host cls

SQL> --等值連接
SQL> --查詢員工信息: 員工號 姓名 月薪  部門名稱
SQL> desc dept
 名稱                                                                                是否為空? 類型
 ----------------------------------------------------------------------------------- -------- --------------------------------------------------------
 DEPTNO                                                                              NOT NULL NUMBER(2)
 DNAME                                                                                        VARCHAR2(14)
 LOC                                                                                          VARCHAR2(13)

SQL> select empno,ename,sal,dname
  2  from emp,dept
  3  where emp.deptno=dept.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> ed
已寫入 file afiedt.buf

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

     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> host cls

SQL> --不等值連接
SQL> --查詢員工信息: 姓名 月薪  工資級別
SQL> select * from tab;

TNAME                          TABTYPE  CLUSTERID                                                                                                     
------------------------------ ------- ----------                                                                                                     
DEPT                           TABLE                                                                                                                  
EMP                            TABLE                                                                                                                  
BONUS                          TABLE                                                                                                                  
SALGRADE                       TABLE                                                                                                                  

SQL> select * from salgrade;

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

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

ENAME        SAL      GRADE                                                                                                                           
---------- ----- ----------                                                                                                                           
SMITH        800          1                                                                                                                           
JAMES        950          1                                                                                                                           
ADAMS       1100          1                                                                                                                           
WARD        1250          2                                                                                                                           
MARTIN      1250          2                                                                                                                           
MILLER      1300          2                                                                                                                           
TURNER      1500          3                                                                                                                           
ALLEN       1600          3                                                                                                                           
CLARK       2450          4                                                                                                                           
BLAKE       2850          4                                                                                                                           
JONES       2975          4                                                                                                                           

ENAME        SAL      GRADE                                                                                                                           
---------- ----- ----------                                                                                                                           
SCOTT       3000          4                                                                                                                           
FORD        3000          4                                                                                                                           
KING        5000          5                                                                                                                           

已選擇14行。

SQL> host cls

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

    DEPTNO DNAME          COUNT(E.EMPNO)                                                                                                              
---------- -------------- --------------                                                                                                              
        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 d.deptno=e.deptno 當不成立時,等號左邊代表的表的信息任然被包含
SQL>          寫法: where d.deptno=e.deptno(+)
SQL> 右外連接: where d.deptno=e.deptno 當不成立時,等號右邊代表的表的信息任然被包含
SQL>          寫法:where d.deptno(+)=e.deptno
SQL> */
SQL> select d.deptno,d.dname,count(e.empno)
  2  from dept d,emp e
  3  where d.deptno=e.deptno(+)
  4  group by d.deptno,d.dname;

    DEPTNO DNAME          COUNT(E.EMPNO)                                                                                                              
---------- -------------- --------------                                                                                                              
        10 ACCOUNTING                  3                                                                                                              
        40 OPERATIONS                  0                                                                                                              
        20 RESEARCH                    5                                                                                                              
        30 SALES                       6                                                                                                              

SQL> ed
已寫入 file afiedt.buf

  1  select d.deptno,d.dname,count(e.empno)
  2  from dept d,emp e
  3  where d.deptno=e.deptno(+)
  4  group by d.deptno,d.dname
  5* order by 1
SQL> /

    DEPTNO DNAME          COUNT(E.EMPNO)                                                                                                              
---------- -------------- --------------                                                                                                              
        10 ACCOUNTING                  3                                                                                                              
        20 RESEARCH                    5                                                                                                              
        30 SALES                       6                                                                                                              
        40 OPERATIONS                  0                                                                                                              

SQL> host cls

SQL> --自連接
SQL> --查詢員工信息:***的老板是***
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 13-7月 -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 13-7月 -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> select e.ename||'的老板是'||b.ename
  2  from emp e,emp b
  3  where e.mgr=b.empno;

E.ENAME||'的老板是'||B.ENAME                                                                                                                          
----------------------------                                                                                                                          
FORD的老板是JONES                                                                                                                                     
SCOTT的老板是JONES                                                                                                                                    
JAMES的老板是BLAKE                                                                                                                                    
TURNER的老板是BLAKE                                                                                                                                   
MARTIN的老板是BLAKE                                                                                                                                   
WARD的老板是BLAKE                                                                                                                                     
ALLEN的老板是BLAKE                                                                                                                                    
MILLER的老板是CLARK                                                                                                                                   
ADAMS的老板是SCOTT                                                                                                                                    
CLARK的老板是KING                                                                                                                                     
BLAKE的老板是KING                                                                                                                                     

E.ENAME||'的老板是'||B.ENAME                                                                                                                          
----------------------------                                                                                                                          
JONES的老板是KING                                                                                                                                     
SMITH的老板是FORD                                                                                                                                     

已選擇13行。

SQL> --自連接:利用表的別名,將同一張表視為多張表
SQL> --層次查詢
SQL> --自連接不太適合操作大表
SQL> 
SQL> 
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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved