數據庫學習6-連接查詢

/*
  集合操作
*/
--並集 
--union all 合併集合
SELECT tt1,tt2,tt3 FROM test1 
  UNION ALL
SELECT * FROM test2;
--union   合併集合且去重複
SELECT tt1,tt2,tt3 FROM test1
  UNION
SELECT * FROM test2;

--交集
SELECT tt1,tt2,tt3 FROM test1
  INTERSECT
SELECT * FROM test2;

--差集 第一個集合減去交集並且去重複
SELECT tt1,tt2,tt3 FROM test1
   MINUS
SELECT * FROM test2;

--rownum
SELECT ROWNUM,emp.* FROM emp WHERE ROWNUM<6;

--通過僞列rownum和集合操作符minus完成分頁查詢
SELECT ROWNUM,emp.* FROM emp 
  WHERE ROWNUM<11 
    MINUS
SELECT ROWNUM,emp.* FROM emp 
  WHERE ROWNUM<3;
  
/**
  連接(聯表)查詢
*/  
--內連接(INNER JOIN或join): 符合連接條件的記錄
SELECT * FROM emp INNER JOIN dept 
       ON emp.deptno=dept.deptno; --連接條件
       
SELECT * FROM emp e,dept d 
       WHERE e.deptno = d.deptno;       

--查詢員工編號,姓名,工作,入職日期,薪水,部門名稱
SELECT empno,ename,job,hiredate,sal,dname
    FROM emp t1 INNER JOIN dept t2 
       ON t1.deptno = t2.deptno;   
       
SELECT empno,ename,job,hiredate,sal,dname
    FROM emp t1 JOIN dept t2 
       ON t1.deptno = t2.deptno;   
       
--外連接
--左外連接(left outer join或left join):符合條件的加上左邊不符合條件的記錄
SELECT * FROM emp e LEFT OUTER JOIN dept d
    ON e.deptno = d.deptno;  
    
SELECT * FROM emp e LEFT JOIN dept d
    ON e.deptno = d.deptno;
    
SELECT * FROM emp e,dept d
    WHERE e.deptno = d.deptno(+); 
    
SELECT * FROM dept d,emp e
    WHERE e.deptno = d.deptno(+);  

SELECT * FROM emp e,dept d
    WHERE d.deptno(+) = e.deptno;          
--右外連接(right outer join或right join):符合條件的加上右邊不符合條件的記錄
SELECT * FROM emp e RIGHT OUTER JOIN dept d
    ON e.deptno = d.deptno;
    
SELECT * FROM emp e RIGHT JOIN dept d
    ON e.deptno = d.deptno; 
    
SELECT * FROM emp e ,dept d
    WHERE e.deptno(+) = d.deptno;    
--全連接(full join)
SELECT * FROM emp e FULL JOIN dept d
    ON e.deptno = d.deptno;      
    
--查詢工作類型是CLERK的員工姓名,工作,薪水,部門名
SELECT ename,job,sal,dname
   FROM emp t1, dept t2
     WHERE t1.deptno = t2.deptno
       AND job = 'CLERK';  
       
SELECT ename,job,sal,dname 
   FROM emp t1 JOIN dept t2 
     ON t1.deptno = t2.deptno 
      WHERE job = 'CLERK';      
      
--查詢員工名字和領導名字
SELECT t1.ename,t2.ename FROM emp t1,emp t2 
    WHERE t1.mgr = t2.empno;                            


練習:

1.  查詢所有員工的名稱,部門編號及部門名稱


2.  列出所有僱員的姓名、部門名稱和薪金


3.  顯示有提成的員工的信息:
    名字、提成、所在部門名稱、所在地區的名稱


4.  列出所有“CLERK”(辦事員)的姓名及其部門名稱


5.  列出部門名稱和這些部門的僱員,
    同時列出那些沒有僱員的部門


6.  列出所有僱員的姓名及其直接上級的姓名


7.  列出入職日期(僱傭日期)早於其直接上級的所有僱員


8.  列出分配有僱員數量的所有部門的詳細信息,
    即使是分配有0個僱員

發佈了108 篇原創文章 · 獲贊 22 · 訪問量 8萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章