Oracle SQL经典查询练手四篇全.docx

上传人:b****5 文档编号:7180956 上传时间:2023-01-21 格式:DOCX 页数:35 大小:177.71KB
下载 相关 举报
Oracle SQL经典查询练手四篇全.docx_第1页
第1页 / 共35页
Oracle SQL经典查询练手四篇全.docx_第2页
第2页 / 共35页
Oracle SQL经典查询练手四篇全.docx_第3页
第3页 / 共35页
Oracle SQL经典查询练手四篇全.docx_第4页
第4页 / 共35页
Oracle SQL经典查询练手四篇全.docx_第5页
第5页 / 共35页
点击查看更多>>
下载资源
资源描述

Oracle SQL经典查询练手四篇全.docx

《Oracle SQL经典查询练手四篇全.docx》由会员分享,可在线阅读,更多相关《Oracle SQL经典查询练手四篇全.docx(35页珍藏版)》请在冰豆网上搜索。

Oracle SQL经典查询练手四篇全.docx

OracleSQL经典查询练手四篇全

OracleSQL:

经典查询练手四篇

  【IT168技术】本文与大家共同讨论与分享ORACLESQL的一些常用经典查询,欢迎大家补充,同时你认为有那些经典的也可分享出来。

在本文中,对每一个问题,你要是认为有什么更好的解决方法也欢迎你及时提出。

交流与分享才能共同进步嘛,感谢!

  经典查询练手第一篇

  本文使用的实例表结构与表的数据如下:

  scott.emp员工表结构如下:

  NameTypeNullable Default Comments

  -------------------------------------------

  EMPNO NUMBER(4)员工号

  ENAME VARCHAR2(10)Y员工姓名

  JOB VARCHAR2(9)Y工作

  MGR NUMBER(4)Y上级编号

  HIREDATEDATEY雇佣日期

  SAL NUMBER(7,2)Y薪金

  COMM NUMBER(7,2)Y佣金

  DEPTNO NUMBER

(2)Y部门编号

  scott.dept部门表

  NameTypeNullable Default Comments

  -----------------------------------------

  DEPTNO NUMBER

(2)部门编号

  DNAME VARCHAR2(14)Y部门名称

  LOC VARCHAR2(13)Y地点

  提示:

工资=薪金+佣金

  scott.emp表的现有数据如下:

SQL> select * from emp;

EMPNOENAME      JOB        MGRHIREDATE          SAL      COMMDEPTNO

----------------------------------------------------------------

7369 SMITH      CLERK      7902 1980-12-17     800.00               20

7499 ALLEN      SALESMAN   7698 1981-2-20     1600.00    300.00     30

7521 WARD      SALESMAN   7698 1981-2-22     1250.00    500.00     30

7566 JONES      MANAGER    7839 1981-4-2      2975.00               20

7654 MARTIN    SALESMAN   7698 1981-9-28     1250.00   1400.00     30

7698 BLAKE      MANAGER    7839 1981-5-1      2850.00               30

7782 CLARK      MANAGER    7839 1981-6-9      2450.00               10

7788 SCOTT      ANALYST    7566 1987-4-19     4000.00               20

7839 KING      PRESIDENT       1981-11-17    5000.00               10

7844 TURNER    SALESMAN   7698 1981-9-8      1500.00      0.00     30

7876 ADAMS      CLERK      7788 1987-5-23     1100.00               20

7900 JAMES      CLERK      7698 1981-12-3      950.00               30

7902 FORD      ANALYST    7566 1981-12-3     3000.00               20

7934 MILLER    CLERK      7782 1982-1-23     1300.00               10

  102 EricHu    Developer  1455 2011-5-26 1   5500.00     14.00     10

  104 huyong    PM         1455 2011-5-26 1   5500.00     14.00     10

  105 WANGJING  Developer  1455 2011-5-26 1   5500.00     14.00     10

17 rowsselected

  Scott.dept表的现有数据如下:

SQL> select * from dept;

DEPTNODNAME          LOC

---------------------------------

    10 ACCOUNTING    NEWYORK

    20 RESEARCH      DALLAS

    30 SALES          CHICAGO

    40 OPERATIONS    BOSTON

    50 50abc          50def

    60 Developer      HaiKou

6 rowsselected

用SQL完成以下问题列表:

1.列出至少有一个员工的所有部门。

2.列出薪金比“SMITH”多的所有员工。

3.列出所有员工的姓名及其直接上级的姓名。

4.列出受雇日期早于其直接上级的所有员工。

5.列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门

6.列出所有“CLERK”(办事员)的姓名及其部门名称。

7.列出最低薪金大于1500的各种工作。

8.列出在部门“SALES”(销售部)工作的员工的姓名,假定不知道销售部的部门编号。

9.列出薪金高于公司平均薪金的所有员工。

10.列出与“SCOTT”从事相同工作的所有员工。

11.列出薪金等于部门30中员工的薪金的所有员工的姓名和薪金。

12.列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金。

13.列出在每个部门工作的员工数量、平均工资和平均服务期限。

14.列出所有员工的姓名、部门名称和工资。

15.列出所有部门的详细信息和部门人数。

16.列出各种工作的最低工资。

17.列出各个部门的MANAGER(经理)的最低薪金。

18.列出所有员工的年工资,按年薪从低到高排序。

  各答案如下,欢迎大家给出不出的解答方式。

--------1.列出至少有一个员工的所有部门。

---------

SQL> select dname from dept where deptno in(select deptno from emp); 

DNAME

--------------

RESEARCH

SALES

ACCOUNTING

--------或--------

SQL> select dname from dept where deptno in(select deptno from emp group by deptno having count(deptno) >=1); 

DNAME

--------------

ACCOUNTING

RESEARCH

SALES

--------2.列出薪金比“SMITH”多的所有员工。

----------

SQL> select * from emp where sal > (select sal from emp where ename = 'SMITH');

EMPNOENAMEJOBMGRHIREDATESALCOMMDEPTNO

----------------------------------------------------------------

7499 ALLENSALESMAN 7698 1981-2-20 1600.00 300.00 30

7521 WARDSALESMAN 7698 1981-2-22 1250.00 500.00 30

7566 JONESMANAGER 7839 1981-4-2 2975.00 20

7654 MARTINSALESMAN 7698 1981-9-28 1250.00 1400.00 30

7698 BLAKEMANAGER 7839 1981-5-1 2850.00 30

7782 CLARKMANAGER 7839 1981-6-9 2450.00 10

7788 SCOTTANALYST 7566 1987-4-19 4000.00 20

7839 KINGPRESIDENT 1981-11-17 5000.00 10

7844 TURNERSALESMAN 7698 1981-9-8 1500.00 0.00 30

7876 ADAMSCLERK 7788 1987-5-23 1100.00 20

7900 JAMESCLERK 7698 1981-12-3 950.00 30

7902 FORDANALYST 7566 1981-12-3 3000.00 20

7934 MILLERCLERK 7782 1982-1-23 1300.00 10

102 EricHuDeveloper 1455 2011-5-26 1 5500.00 14.00 10

104 huyongPM 1455 2011-5-26 1 5500.00 14.00 10

105 WANGJINGDeveloper 1455 2011-5-26 1 5500.00 14.00 10

16 rowsselected

--------3.列出所有员工的姓名及其直接上级的姓名。

----------

SQL> select a.ename,(select ename from empb where b.empno=a.mgr) as boss_name fromempa; 

ENAMEBOSS_NAME

--------------------

SMITHFORD

ALLENBLAKE

WARDBLAKE

JONESKING

MARTINBLAKE

BLAKEKING

CLARKKING

SCOTTJONES

KING 

TURNERBLAKE

ADAMSSCOTT

JAMESBLAKE

FORDJONES

MILLERCLARK

EricHu 

huyong 

WANGJING 

17 rowsselected

--------4.列出受雇日期早于其直接上级的所有员工。

----------

SQL> select a.ename from empa where a.hiredate<(select hiredate from empb where b.empno=a.mgr); 

ENAME

----------

SMITH

ALLEN

WARD

JONES

BLAKE

CLARK 

6 rowsselected

--------5.列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门----------

SQL> select a.dname,b.empno,b.ename,b.job,b.mgr,b.hiredate,b.sal,b.deptno

2 from depta left join empb on a.deptno=b.deptno;

DNAMEEMPNOENAMEJOBMGRHIREDATESALDEPTNO

---------------------------------------------------------------------

RESEARCH 7369 SMITHCLERK 7902 1980-12-17 800.00 20

SALES 7499 ALLENSALESMAN 7698 1981-2-20 1600.00 30

SALES 7521 WARDSALESMAN 7698 1981-2-22 1250.00 30

RESEARCH 7566 JONESMANAGER 7839 1981-4-2 2975.00 20

SALES 7654 MARTINSALESMAN 7698 1981-9-28 1250.00 30

SALES 7698 BLAKEMANAGER 7839 1981-5-1 2850.00 30

ACCOUNTING 7782 CLARKMANAGER 7839 1981-6-9 2450.00 10

RESEARCH 7788 SCOTTANALYST 7566 1987-4-19 4000.00 20

ACCOUNTING 7839 KINGPRESIDENT 1981-11-17 5000.00 10

SALES 7844 TURNERSALESMAN 7698 1981-9-8 1500.00 30

RESEARCH 7876 ADAMSCLERK 7788 1987-5-23 1100.00 20

SALES 7900 JAMESCLERK 7698 1981-12-3 950.00 30

RESEARCH 7902 FORDANALYST 7566 1981-12-3 3000.00 20

ACCOUNTING 7934 MILLERCLERK 7782 1982-1-23 1300.00 10

ACCOUNTING 102 EricHuDeveloper 1455 2011-5-26 1 5500.00 10

ACCOUNTING 104 huyongPM 1455 2011-5-26 1 5500.00 10

ACCOUNTING 105 WANGJINGDeveloper 1455 2011-5-26 1 5500.00 10

50abc 

OPERATIONS 

Developer 

20 rowsselected

 

 

 

--------6.列出所有“CLERK”(办事员)的姓名及其部门名称。

----------

SQL> select a.ename,b.dname from empa join deptb on a.deptno=b.deptno and a.job='CLERK'; 

ENAMEDNAME

------------------------

SMITHRESEARCH

ADAMSRESEARCH

JAMESSALES

MILLERACCOUNTING

--------7.列出最低薪金大于1500的各种工作。

----------

SQL> select distinct job as HighSalJob from emp group by job having min(sal)>1500;

HIGHSALJOB

----------

ANALYST

Developer

MANAGER

PM

PRESIDENT

--------8.列出在部门“SALES”(销售部)工作的员工的姓名,假定不知道销售部的部门编号。

----------

SQL> select ename from emp where deptno=(select deptno from dept where dname='SALES'); 

ENAME

----------

ALLEN

WARD

MARTIN

BLAKE

TURNER

JAMES 

6 rowsselected

--------9.列出薪金高于公司平均薪金的所有员工。

----------

SQL> select ename from emp where sal>(select avg(sal) from emp); 

ENAME

----------

JONES

BLAKE

SCOTT

KING

FORD

EricHu

huyong

WANGJING 

8 rowsselected

--------10.列出与“SCOTT”从事相同工作的所有员工。

--------

SQL> select ename from emp where job=(select job from emp where ename='SCOTT');

ENAME

----------

SCOTT

FORD

--------11.列出薪金等于部门30中员工的薪金的所有员工的姓名和薪金。

---------

SQL> select a.ename,a.sal from empa where a.sal in (select b.sal

2 from empb where b.deptno=30) and a.deptno<>30; 

ENAMESAL

-------------------

--------12.列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金。

---------

SQL> select ename,sal from emp where sal>(select max(sal) from emp where deptno=30); 

ENAMESAL

-------------------

JONES 2975.00

SCOTT 4000.00

KING 5000.00

FORD 3000.00

EricHu 5500.00

huyong 5500.00

WANGJING 5500.00 

7 rowsselected

--------13.列出在每个部门工作的员工数量、平均工资和平均服务期限。

---------

SQL> select (select b.dname from deptb where a.deptno=b.deptno) as deptname,count(deptno) as deptcount,avg(sal) as deptavgsal

2 from empa group by deptno; 

DEPTNAMEDEPTCOUNTDEPTAVGSAL

----------------------------------

ACCOUNTING 6 4208.33333

RESEARCH 5 2375

SALES 6 1566.66666

 

--------14.列出所有员工的姓名、部门名称和工资。

---------

SQL> select a.ename,(select b.dname from deptb where b.deptno=a.deptno) as deptname,sal from empa; 

ENAMEDEPTNAMESAL

---------------------------------

SMITHRESEARCH 800.00

ALLENSALES 1600.00

WARDSALES 1250.00

JONESRESEARCH 2975.00

MARTINSALES 1250.00

BLAKESALES 2850.00

CLARKACCOUNTING 2450.00

SCOTTRESEARCH 4000.00

KINGACCOUNTING 5000.00

TURNERSALES 1500.00

ADAMSRESEARCH 1100.00

JAMESSALES 950.00

FORDRESEARCH 3000.00

MILLERACCOUNTING 1300.00

EricHuACCOUNTING 5500.00

huyongACCOUNTING 5500.00

WANGJINGACCOUNTING 5500.00

17 rowsselected

--------15.列出所有部门的详细信息和部门人数。

---------

SQL> select a.deptno,a.dname,a.loc,(select count(deptno) from empb where b.deptno=a.deptno group by b.deptno) as deptcount from depta; 

DEPTNODNAMELOCDEPTCOUNT

-------------------------------------------

10 ACCOUNTINGNEWYORK 6

20 RESEARCHDALLAS 5

30 SALESCHICAGO 6

40 OPERATIONSBOSTON 

50 50abc50def 

60 DeveloperHaiKou 

6 rowsselected

--------16.列出各种工作的最低工资。

---------

SQL> select job,avg(sal) from emp group by job;

JOB         AVG(SAL)

-------------------

ANALYST         3500

CLERK         1037.5

Developer       5500

MANAGER   2758.33333

PM              5500

PRESIDENT       5000

SALESMAN        1400

7 rowsselected

--------17.列出各个部门的MANAGER(经理)的最低薪金。

--------

SQL> select deptno,min(sal) from emp where job='MANAGER' group by deptno;

DEPTNO   MIN(SAL)

----------------

    10       2450

    20       2975

30       2850

--------18.列出所有员工的年工资,按年薪从低到高排序。

---------

SQL> select ename,(sal+nvl(comm,0))*12 as salpersal from emp order by salpersal;

ENAME      SALPERSAL

--------------------

SMITH            9600

JAMES           11400

ADAMS           13200

MILLER          15600

TURNER         

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 农林牧渔 > 林学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1