Orcla 數據庫復習2 --子查詢和表連接


 子查詢和表連接
 ①.查詢掙錢最多的人的名字
 SELECT ename,sal FROM emp
 WHERE sal=(SELECT MAX(sal) FROM emp);
 ②.查詢有哪些人的工資位於全部人的平均工資之上
 SELECT ename,sal FROM emp
 WHERE sal > (SELECT AVG(sal) FROM emp);
 ③.求部門中哪些人的薪水最高:
 SELECT ename,sal FROM emp
 JOIN (SELECT MAX(sal) max_sal,deptno FROM emp GROUP BY deptno) t
 ON emp.sal =t.max_sal AND emp.deptno = t.deptno;
④.求出員工的名字和他的經理人姓名
  SELECT  e1.ename, e2.ename FROM
  emp e1 JOIN emp e2
  ON e1.mgr = e2.empno;
 ⑤.查詢出每一個人的薪水等級
  SELECT ename,grade FROM emp e JOIN salgrade s
  ON  (e.sal BETWEEN s.losal AND s.hisal);
 ⑥查詢出每一個人的部門名稱和薪水等級
 SELECT ename,dname,grade FROM
 emp e JOIN dept d ON (e.deptno =d.deptno)
 JOIN salgrade s ON (e.sal BETWEEN s.losal AND s.hisal)
 ⑦(左外連接) 查詢出雇員的名字和他經理人的名字
 SELECT e1.ename, e2.ename FROM
 emp e1 LEFT JOIN emp e2
 ON e1.mgr = e2.empno;
⑧(右外連接) 查詢出全部雇員的部門名稱
 SELECT ename ,dname FROM
 emp e RIGHT JOIN dept d
 ON e.deptno = d.deptno;
 ⑨(全外連接) 查詢出全部雇員的部門名稱
 SELECT ename ,dname FROM
 emp e FULL JOIN dept d
 ON e.deptno = d.deptno;
 ⑩求部門平均薪水的等級
 SELECT deptno,avg_sal,grade FROM
 (SELECT deptno,AVG(sal) avg_sal FROM emp GROUP BY deptno) t
 JOIN salgrade s
 ON t.avg_sal BETWEEN s.losal AND s.hisal;
--求部門平均的薪水等級
  SELECT deptno,AVG(grade) FROM
 (SELECT deptno,ename,grade FROM emp JOIN salgrade s ON
  emp.sal BETWEEN s.losal AND s.hisal) t
  GROUP BY deptno;
--求雇員中哪些人是經理人
 SELECT  ename FROM emp
 WHERE  empno  in(SELECT DISTINCT mgr FROM emp);
--不准用組函數,求薪水的最高值
  SELECT sal FROM emp WHERE sal NOT IN
 (SELECT DISTINCT  e1.sal FROM emp e1  JOIN  emp e2
 ON e1.sal< e2.sal);
--平均薪水最高的部門的部門編號
SELECT deptno ,avg_sal FROM
( SELECT deptno, AVG(sal) avg_sal FROM emp GROUP BY deptno);
WHERE avg_sal =
(SELECT MAX(avg_sal) FROM
( SELECT deptno, AVG(sal) avg_sal FROM emp GROUP BY deptno));
--平均薪水最高的部門的部門名稱
SELECT dname FROM dept WHERE deptno =
(SELECT deptno  FROM
        ( SELECT deptno, AVG(sal) avg_sal FROM emp GROUP BY deptno)
 WHERE avg_sal =
(SELECT MAX(avg_sal) FROM
        ( SELECT deptno, AVG(sal) avg_sal FROM emp GROUP BY deptno)
  )
);

--求平均薪水的等級最低的部門的部門名稱
SELECT dept.dname,t1.deptno,grade,avg_sal FROM
(
SELECT deptno,grade,avg_sal FROM
(SELECT AVG(sal) avg_sal, deptno FROM emp GROUP BY deptno) t JOIN salgrade s
ON t.avg_sal BETWEEN s.losal AND s.hisal
) t1
JOIN dept ON (t1.deptno = dept.deptno)
WHERE t1.grade =
(SELECT MIN(grade) FROM
(SELECT deptno,grade,avg_sal FROM
(SELECT AVG(sal) avg_sal, deptno FROM emp GROUP BY deptno) t JOIN salgrade s
ON t.avg_sal BETWEEN s.losal AND s.hisal))

--求部門經理人平均薪水最低的部門名稱


--求比普通員工的最高薪水還要高的經理人名稱
  SELECT ename  FROM emp WHERE
  empno IN (SELECT DISTINCT mgr FROM emp WHERE mgr IS NOT NULL)
  AND sal >
(SELECT max(sal) FROM  emp WHERE empno NOT  IN
(SELECT DISTINCT mgr FROM emp WHERE mgr IS NOT NULL))

--求薪水最高的前5名雇員
SELECT ename,sal
FROM (
SELECT ename,sal FROM emp ORDER BY sal DESC
)
WHERE ROWNUM <=5;
--求薪水最高的第6到第10名雇員
SELECT ename,sal FROM(
SELECT ename,sal, ROWNUM r FROM(
SELECT ename,sal FROM emp ORDER BY sal DESC)
)

WHERE r>=6 AND r<=10;


注:查詢語句是自己看馬士兵的視頻敲出來的



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM