/*
集合操作
*/
--並集
--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個僱員