Oracle习题

  1. 创建表emp,包括empno,ename,sal,job四列,其类型分别是NUMBER(8),VARCHAR2(15),NUMBER(4),VARCHAR2(10),在empno上创建主键约束。

    CREATE TABLE emp(
    	empno NUMBER(8),
    	ename VARCHAR2(15),
        sal NUMBER(4),
        job VARCHAR2(10)
    )
    
  2. 获取当前的SCN号scn1。

    select current_scn from v$database;//注意:必须是系统用户,不能是普通用户
    
  3. 对表emp插入6行记录:

    (20190011,‘Alice’,‘3500’,‘clerk’)

    (20190022,‘Bob’,‘4700’,‘clerk’)

    (20190033,‘Wanger’,‘5500’,‘clerk’)

    (20190034,‘Lisan’,‘4600’,‘clerk’)

    (20190045,‘Zhangsi’,‘5000’,‘clerk’)

    并提交事务。获取当前的SCN号,scn2。

    INSERT INTP emp VALUES(20190011,'Alice',3500,'clerk')
    INSERT INTP emp VALUES(20190022,'Bob','4700','clerk')
    INSERT INTP emp VALUES(20190033,'Wanger','5500','clerk')
    INSERT INTP emp VALUES(20190034,'Lisan','4600','clerk')
    INSERT INTP emp VALUES(20190034,'Lisan','4600','clerk')
    INSERT INTP emp VALUES(20190045,'Zhangsi','5000','clerk')
    
    select current_scn from v$database;
    
  4. 修改数据:将工号为20190011和20190034的工资增加800,并提交事务,获取当前的SCN号scn3。

    UPDATE emp SET sal=sal+800 WHERE empno=20190011 OR empno=20190034;
    
  5. 查询工号为20190011的员工信息。

    SELECT * FROM emp WHERE empno=20190011
    
  6. 将表emp闪回到SCN号为scn2时的状态,查询工号为20190011的员工的信息。

     FLUSHBACK TABLE emp TO SCN 662421;
     SELECT * FROM emp WHERE empno=20190011;
    

根据Oracle数据库scott模式下的emp和dept表,完成下列操作:
  1. 查询20号部门的所有员工信息。

    SELECT * FROM emp WHERE deptno=20;
    
  2. 查询所有工种为CLERK的员工的员工号、员工名和部门号。

    SELECT empno,ename,deptno FROM emp WHERE job='CLERK';
    
  3. 查询奖金高于工资的员工信息。

    SELECT * FROM emp WHERE comm > sal;
    
  4. 查询奖金高于工资20%的员工信息。

    SELECT * FROM emp WHERE comm > 0.2*sal;
    
  5. 查询10号部门中工种为MANAGER和20号部门中工种为CLERK的员工的详细信息。

    SELECT * FROM emp WHERE deptno=10 AND job='MANAGER' OR deptno=20 AND job='CLERK';
    
  6. 查询所有工种不是MANAGER和CLERK,且工资大于或等于2000的员工的详细信息。

    SELECT * FROM emp WHERE job NOT IN ('MANAGER','CLERK') AND sal >=2000;
    
  7. 查询有奖金的员工的不同工种。

    SELECT DISTINCT job FROM emp WHERE comm IS NOT NULL;
    
  8. 查询所有员工工资与奖金的和。

    SELECT ename,(sal+NVL(comm,0)) sumsal FROM emp;
    
  9. 查询没有奖金或奖金低于100的员工的信息。

    SELECT * FROM emp WHERE comm IS NULL OR comm < 100;
    
  10. 查询各月倒数第二天入职的员工信息。

    SELECT * FROM emp WHERE LAST_DAY(hiredate)-2=hiredate;
    
  11. 查询工龄大于或等于10年的员工信息。

    SELECT * FROM emp WHERE MONTHS_BETWEEN(SYSDATE,hiredate)/12>=10;
    
  12. 查询员工信息,要求以首字母大写的方式显示所有员工的姓名。

    SELECT INITCAP(ename) ename FROM emp;
    
  13. 查询员工名正好为6个字符的员工的信息。

    SELECT * FROM emp WHERE LENGTH(ename)=6;
    
  14. 查询员工名字中不包含字母"S"员工。(逆向)

    SELECT * FROM emp WHERE ename NOT LIKE '%S%';
    
  15. 查询员工姓名的第2个字母为"M"的员工信息。

    SELECT * FROM emp WHERE ename LIKE '_M%';
    
  16. 查询所有员工姓名的前3个字符。

    SELECT SUBSTR(ename,0,3) subname FROM emp;
    
  17. 查询所有员工的姓名,如果包含字母"s",则用"S"替换。

    SELECT REPLACE(ename,'s','S') newname FROM emp;
    
  18. 查询员工的姓名和入职日期,并按入职日期从先到后进行排列。

    SELECT ename,hiredate FROM emp ORDER BY hiredate DESC;
    
  19. 显示所有的姓名、工种、工资和奖金,按工种降序排列,若工种相同则按工资升序排列。

    SELECT ename,job,sal,comm FROM emp ORDER BY job DESC,sal ASC;
    
  20. 显示所有员工的姓名、入职的年份和月份,按入职日期所在的月份排序,若月份相同则按入职的年份排序。

    SELECT ename,EXTRACT(YEAR FROM hiredate) year,EXTRACT(MONTH FROM hiredate) month FROM emp ORDER BY month desc;
    
  21. 查询在2月份入职的所有员工信息。

    SELECT  * FROM emp WHERE EXTRACT(MONTH FROM hiredate)=2;
    
  22. 查询至少有一个员工的部门信息。

    SELECT * FROM dept WHERE deptno IN (SELECT DISTINCT deptno FROM emp);
    
  23. 查询工资比SMITH员工工资高的所有员工信息。

    SELECT * FROM emp WHERE sal > (SELECT sal FROM emp WHERE eanme = 'SMITH');
    
  24. 查询所有员工的姓名及其直接上级的姓名。

    SELECT a.ename,b.ename FROM emp a,emp b WHERE a.mgr=b.empno;
    
  25. 查询入职日期早于其直接上级领导的所有员工信息。

    SELECT a.* FROM emp a,emp b WHERE a.mgr=b.empno AND a.hiredate < b.hiredate;
    
  26. 查询所有部门及其员工信息,包括那些没有员工的部门。

    SELECT * FROM dept d LEFT OUTER JOIN emp e ON(d.deptno=e.deptno);
    
  27. 查询所有员工及其部门信息,包括那些还不属于任何部门的员工。

    SELECT * FROM dept d RIGHT OUTER JOIN emp e ON(d.deptno=e.deptno);
    
  28. 查询所有工种为CLERK的员工的姓名及其部门名称。

    SELECT e.ename,d.dname FROM emp e,dept d WHERE e.deptno=d.deptno AND e.job='CLERK'; 
    
  29. 查询最低工资大于2500的各种工作。

    SELECT job FROM (SELECT job,MIN(sal) sal FROM emp GROUP BY job) WHERE sal <2500;
    
  30. 查询平均工资低于2000的部门及其员工信息。

    SELECT * FROM dept d JOIN emp e ON d.deptno=e.deptno WHERE d.deptno IN(SELECT deptno FROM emp GROUP BY deptno HAVING AVG(sal)>2500)
    
  31. 查询在SALES部门工作的员工的姓名信息。

    SELECT ename FROM emp WHERE deptno = (SELECT deptno FROM dept WHERE dname='SALES');
    
  32. 查询工资高于公司平均工资的所有员工信息。

    SELECT * FROM emp WHERE sal > (SLECT AVG(sal) FROM emp);
    
  33. 查询与SMITH员工从事相同工作的所有员工信息。

    SELECT * FROM emp WHERE job=(SELECT job FROM emp WHERE ename='SMITH')
    
  34. 列出工资等于30号部门中某个员工工资的所有员工的姓名和工资。

    SELECT ename,sal FROM emp WHERE sal IN(SELECT sal FROM emp WHERE deptno=30);
    
  35. 查询工资高于30号部门中工作的所有员工的工资的员工姓名和工资。

    SELECT ename,sal FROM emp WHERE sal IN(SELECT MAX(sal) FROM emp WHERE deptno=30);
    
  36. 查询每个部门中的员工数量、平均工资和平均工作年限。

    SELECT e.deptno,COUNT(empno) emp_num,AVG(sal) avg_sal,AVG(MONTHS_BETWEEN(SYSDATE,hiredate)/12) avg_year 
    FROM emp e JOIN dept d ON e.deptno=d.deptno
    GROUP BY e.deptno;
    
  37. 查询各个部门的详细信息以及部门人数、部门平均工资。

    SELECT d.deptno,COUNT(empno) emp_num,AVG(sal) avg_sal
    FROM emp e JOIN dept d ON e.deptno=d.deptno
    GROUP BY d.deptno;
    
  38. 查询各个部门中的不同工种的最高工资。

    SELECT job,MAX(sal) max_sla FROM emp GROUP BY job; 
    
  39. 查询10号部门员工以及领导的信息。

    SELECT * FROM emp WHERE deptno=10 OR mgr IN (SELECT mgr FROM emp WHERE deptno=10);
    
  40. 查询工资为某个部门平均工资的员工信息。

    SELECT * FROM emp WHERE sal IN (SELECT AVG(sal) avg_sal FROM emp GROUP BY deptno);
    
  41. 查询工资高于本部门平均工资的员工的信息。

    SELECT * FROM emp e WHERE sal > (SELECT AVG(sal) avg_sal FROM emp WHERE deptno=e.deptno);
    
  42. 查询工资高于本部门平均工资的员工的信息及其部门的平均工资。

    SELECT e.*,s.* FROM emp e,(SELECT AVG(sal) avg_sal FROM emp WHERE deptno=e.deptno) s WHERE sal > s.avg_sal ;
    
  43. 查询工资高于20号部门某个员工工资的员工的信息。

    SELECT * FROM emp WHERE sal > (SELECT MIN(sal) FROM emp WHERE deptno=20);
    
  44. 统计各个工种的人数与平均工资。

    SELECT job,COUNT(empno),AVG(sal) FROM emp GROUP BY job;
    
  45. 统计每个部门中各个工种的人数与平均工资。

    SELECT deptno,job,COUNT(empno),AVG(sal) FROM emp GROUP BY deptno,job ORDER BY deptno,job;
    
  46. 查询工资、奖金与10 号部门某个员工工资、奖金都相同的员工的信息。

    SELECT e.* FROM emp e JOIN (SELECT * FROM emp WHERE deptno=10) t ON e.sal=t.sal AND e.sal=t.sal AND nvl(e.comm,0)=NVL(t.comm,0) AND e.deptno!=10;  
    
  47. 查询部门人数大于5的部门的员工的信息。

    SELECT * FROM emp WHERE deptno IN(SELECT deptno FROM emp GROUP BY deptno HAVING COUNT(*)>5);
    
  48. 查询所有员工工资都大于2000的部门的信息。

    SELECT * FROM dept WHERE deptno IN(SELECT deptno FROM emp GROUP BY deptno HAVING MIN(sal)>2000)
    
  49. 查询所有员工工资都大于2000的部门的信息及其员工信息。

    SELECT * FROM dept JOIN dept 
    WHERE deptno IN(SELECT deptno FROM emp GROUP BY deptno HAVING MIN(sal)>2000)
    
  50. 查询所有员工工资都在2000~3000之间的部门的信息。

    SELECT * FROM dept WHERE deptno IN (SELECT deptno FROM emp GROUP BY deptno HAVING MIN(sal)>=2000 AND MAX(sal)<=3000)
    
  51. 查询所有员工工资都在2000~3000之间的员工所在部门的员工信息。

    SELECT * FROM emp WHERE deptno IN (SELECT deptno FROM emp GROUP BY deptno HAVING MIN(sal)>=2000 AND MAX(sal)<=3000)
    
  52. 查询人数最多的部门信息。

    SELECT * FROM dept WHERE deptno (SELECT deptno,COUNT(*) count_emp FROM emp)
    
  53. 查询30号部门中工资排序前3名的员工信息。

    SELECT * FROM emp WHERE empno IN
    (SELECT empno FROM (SELECT empno FROM emp WHERE deptno=30 ORDER BY sal DESC) WHERE ROWNUM<4)
    
  54. 查询所有员工中工资排在5~10名之间的员工信息。

    SELECT * FROM (SELECT ROWNUM id,t.* FROM (SELECT * FROM emp ORDER BY sal) t) s WHERE id BETWEEN 5 AND 10;
    
  55. 向emp表插入一条记录:员工号为1357,员工的名字为oracle,工资为2050,部门号为20,入职日期为2002年5月10日。

    INSERT INTO emp VALUES(1357,'oracle','CLERK',NULL,'2002-5-10',2050,NULL,20);
    
  56. 向emp表插入一条记录:员工号为8000,员工的名字为FAN,工资为2050,其它信息与SMITH员工的信息相同。

    INSERT INTO emp SELECT 8000,'FAN',job,mgr,hiredate,sal,comm,deptno FROM emp WHERE ename='SMITH';
    
  57. 将各个部门员工的工资修改为改员工所在部门的平均工资加1000。

    UPDATE emp SET sal=(SELECT AVG(sal) FROM emp)+1000;
    
  58. 查询所有员工入职以来的工作期限,用**年**月**日的形式表示。

    SELECT ename,TRUNC(MONTHS_BETWEEN(SYSDATE,hiredate)/12)||'年'||TRUNC(MOD(MONTHS_BETWEEN(SYSDATE,hiredate),12))||'月'||TRUNC(SYSDATE - ADD_MONTHS(hiredate,MONTHS_BETWEEN(SYSDATE,hiredate)))||'日' hire FROM emp;
    
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值