您好,登錄后才能下訂單哦!
Oracle系列《五》:SQL綜合練習
【1】列出最低薪金大于1500的各種工作及從事此工作的全部雇員人數
select job,count(*) from emp group by job having min(sal)>1500
【2】列出在部門'SALES'工作的員工姓名
<1>先查詢SALES的部門編號
SQL> SELECT deptno FROM dept WHERE dname='SALES';
<2>SELECT ename FROM emp
WHERE deptno=(SELECT deptno FROM dept WHERE dname='SALES');
【3】列出薪金高于公司平均薪金的所有員工,所在部門,上級領導,公司的工資等級
<1>求出公司平均薪金
SQL> SELECT AVG(sal) FROM emp;
<2>列出薪金高于平均薪金的所有員工
SQL> SELECT * FROM emp
WHERE sal>(SELECT AVG(sal) FROM emp);
<3>查詢所在部門信息
SQL> SELECT e.*,d.dname,d.loc FROM emp e,dept d
WHERE sal>(SELECT AVG(sal) FROM emp) AND e.deptno=d.deptno;
<4>查詢上級領導
SQL>
SQL>SELECT e.empno,e.ename,m.empno,m.ename,d.deptno,d.dname,d.loc
FROM emp e,dept d,emp m
WHERE e.sal>(SELECT AVG(sal) FROM emp) AND e.deptno=d.deptno AND e.mgr = m.empno(+);
<5>求出工資的工資等級
SQL> SELECT
e.empno,e.ename,s.grade,m.empno,m.ename,d.deptno,d.dname,d.loc
FROM emp e,dept d,emp m,salgrade s
WHERE e.sal>(SELECT AVG(sal) FROM emp) AND e.deptno=d.deptno AND e.mgr=m.empno(+)
AND e.sal BETWEEN s.losal AND s.hisal;
【4】列出與"SCOTT"從事相同工作的所有員工及部門名稱
<1>找出與SCOTT相同工作的雇員,但不能包括自己
SQL> SELECT empno,ename,job FROM emp
WHERE job=(SELECT job FROM emp WHERE ename='SCOTT') AND ename!='SCOTT';
<2>與部門表關聯,查詢部門名稱
SQL> SELECT e.empno,e.ename,e.job,d.dname FROM emp e,dept d
WHERE job=(SELECT job FROM emp WHERE ename='SCOTT') AND ename!='SCOTT';
AND e.deptno=d.deptno;
【5】列出薪金等于部門30中員工的薪金的所有員工的姓名和薪金 (本題無結果,薪金都和30號部門不一樣)
<1>列出部門30員工的薪金
SQL> SELECT sal FROM emp WHERE deptno=30;
<2>上述條件作為子查詢,這里注意上述結果是返回多條記錄的,所以要用IN
SQL> SELECT ename,sal FROM emp
WHERE sal IN(SELECT sal FROM emp WHERE deptno=30) AND deptno!=30;
【6】列出在每個部門工作的員工數量、平均工資和平均服務期限
<1>每個部門的員工數量:可求出部門名稱
SQL> SELECT d.dname,COUNT(e.empno)
FROM emp e,dept d
WHERE e.deptno=d.deptno GROUP BY d.dname;
<2>求平均工資和服務年限
SQL> SELECT d.dname,COUNT(e.empno),AVG(e.sal),AVG(MONTH_BETWEENS(sysdate,hiredate)/12) year
FROM emp e,dept d
WHERE e.deptno=d.deptno GROUP BY d.dname;
【7】列出所有部門的詳細信息和部門人數
<1>列出所有部門人數
SQL> SELECT deptno,COUNT(empno) FROM emp GROUP BY deptno;
<2>將以上查詢當做一張臨時表
SQL> SELECT d.*,ed.cou
FROM dept d,(SELECT deptno,COUNT(empno) cou from emp GROUP BY deptno) ed
WHERE d.deptno = ed.deptno;
但是以上沒有40部門的信息,則應該使用NVL和左連接操作
SQL> SELECT d.*,NVL(ed.cou,0)
FROM dept d,(SELECT deptno,COUNT(empno) cou FROM emp GROUP BY deptno) ed
WHERE d.deptno = ed.deptno(+);
【8】列出各種工作的最低工資及從事該工作的雇員姓名
<1>按照工作分組,使用MIN函數求出最低工資
SQL> SELECT job,MIN(sal) FROM emp GROUP BY job;
<2>按照工資查詢雇員信息
SQL> SELECT * FROM emp
WHERE sal IN (SELECT MIN(sal) FROM emp GROUP BY job);
【9】列出各個部門 MANAGER的最低薪金
SQL> SELECT deptno,MIN(sal) FROM emp
WHERE job='MANAGER' GROUP BY deptno;
【10】列出所有員工的年工資,按年薪從低到高排序
SQL> SELECT ename,(sal+NVL(comm,0))*12 income
FROM emp ORDERY BY income;
【11】求出部門名稱中,帶'S'字符的部門員工,工資合計,部門人數
<1>使用模糊查詢,獲得部門編號
SQL> SELECT deptno FROM dept WHERE dname LIKE '%S%';
<2>上面作為子查詢
SQL> SELECT deptno,SUM(sal),COUNT(empno) FROM emp
WHERE deptno IN(SELECT deptno FROM dept WHERE dname LIKE '%S%') GROUP BY deptno;
【12】給任職10年以上的人加薪10%
SQL> UPDATE emp SET sal=sal+(sal*0.1)
WHERE MONTH_BETWEENS(sysdate,hiredate)/12>10;
【綜合題】有個學生運動會比賽信息的數據庫,需要建立如下的表,結構如下 運動員sporter: (運動員編號 sporterid,運動員姓名 name,運動員性別 sex,所屬系號 department)
項目item: (項目編號itemid,項目名稱itemname,項目比賽地點 location)
成績grade: (運動員編號 sporterid,項目編號itemid,積分mark)
1、建表要求
<1>定義各個表的主外鍵約束
<2>運動員姓名和所屬系別不能為空
<3>積分要么控制,要么為6,4,2,0,
CREATE TABLE sporter(
sporterid NUMBER(4) PRIMARY KEY,
name VARCHAR2(20) NOT NULL,
sex VARCHAR2(2) NOT NULL,
department VARCHAR2(20) NOT NULL,
CONSTRAINT sporter_sex_CK CHECK(sex IN('M','F'))
);
CREATE TABLE item(
itemid VARCHAR2(4)PRIMARY KEY,
itemname VARCHAR2(20) NOT NULL,
location VARCHAR2(20) NOT NULL );
CREATE TABLE grade(
sporterid NUMBER(4),
itemid VARCHAR2(20),
mark NUMBER(2),
CONSTRAINT sporter_grade_fk FOREIGN KEY(sporterid) REFERENCES sporter(sporterid) ON DELETE CASCADE,
CONSTRAINT item_grade_fk FOREIGN KEY(itemid) REFERENCES item(itemid) ON DELETE CASCADE,
CONSTRAINT grade_mark_CK CHECK(mark IN(6,4,2,0))
);
記錄可自己視情況插入,完成以上的查詢語句
1、求出目前總積分最高的系名,及其積分
SQL> SELECT s.department,SUM(g.mark) sum FROM sporter s,grade g
WHERE s.sporterid=g.sporterid GROUP BY s.department ORDER BY sum DESC;
當然上述查出來的結果是排序的多條記錄,使用ROWNUM最為簡便
SQL> SELECT * FROM (
SELECT s.department,SUM(g.mark) sum FROM sporter s,grade g
where s.sporterid = g.sporterid GROUP BY s.department ORDER BY sum DESC)
WHERE ROWNUM=1;
2、找出場地為'S1',進行比賽的各項目名稱及其冠軍的姓名
<1>首先確定一操場中的全部項目和每個項目的最高成績
SQL> SELECT i.itemname,s.name,g.mark FROM item i,grade g,sporter s
WHERE i.location='S1' AND i.itemid = g.itemid AND s.sporterid = g.sporterid;
<2>根據上述結果求出最高分
SQL> SELECT i.item,s.name,g.mark FROM item i,grade g,sporter s
WHERE i.location='S1' AND i.itemid = g.itemid AND s.sporterid AND g.mark=6;
3、找出參加了wilson所參加過的項目的其他同學的姓名
<1>找到wilson參加過的項目編號
SQL> SELECT g.itemid FROM sporter s,grade g
WHERE s.sporterid=g.sporterid AND s.name='wislon';
<2>SELECT DISTINCT s.name FROM sporter s, grade g
WHERE s.sporterid=g.sporterid AND s.name<>'wilson';
AND g.itemid IN
(SELECT g.itemid FROM sporter s,grade g WHERE s.sporterid=g.sporterid AND s.name='wilson');
4、wilson使用了違禁藥物,成績記為0
SQL> UPDATE grade SET makr=0
WHERE sporterid=(SELECT sporterid FROM sporter WHERE name='wilson');
5、刪除S2項目
SQL> DELETE FROM item WHERE itemid='S2'
到此ORACLE基礎語法等訓練結束了,后續(xù)我們還將進行ORACLE體系結構的學習
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。