–用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.列出所有员工的年工资,按年薪从低到高排序。
–19 查询雇员表中,姓名为SMITH的雇员,截止到今天共工作了多少周,则可以使用如下的SQL语句
–20 查询各部门的最高薪水、最低薪水、平均薪水….

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

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

执行结果如下:

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

select * from emp where sal > (select sal from emp where ename = 'SMITH');
--首先将姓名为小写得部分变为大写
update emp set ename=replace(ename,substr (ename,length(ename),length(ename)),upper(substr(ename,length(ename),length(ename))));
--查询是否变更;
select * from emp;
--最后进行查询
select * from emp where sal > (select sal from emp where ename = 'SMITH');

*由于之前练习将ename中最后一个字母变为小写,所以查不到SMITH,因此得先将小写变为大写后,在进行查询
执行结果如下:


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

select a.ename,(select ename from emp b where b.empno=a.mgr) as boss_name from emp a;

执行结果如下:

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

select a.ename from emp a where a.hiredate<(select hiredate from emp b where b.empno=a.mgr);

执行结果如下:

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

select a.dname,b.empno,b.ename,b.job,b.mgr,b.hiredate,b.sal,b.deptno from dept a left join emp b on a.deptno=b.deptno;

执行结果如下:

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

select a.ename,b.dname from emp a join dept b on a.deptno=b.deptno and a.job='CLERK';

执行结果如下:

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

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

执行结果如下:

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

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

执行结果如下:

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

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

执行结果如下:

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

select ename from emp where job=(select job from emp where ename='SMITH');

执行结果如下:

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

select ename,sal from empwhere sal in (select sal from emp where deptno=30);

执行结果如下:

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

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

执行结果如下:

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

select deptno,count(*),avg(a.sal),avg(sysdate-HIREDATE) from emp a group by deptno;

执行结果如下:

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

select ename,(select dname from dept a where a.deptno=b.deptno)as dname,sal from emp b;

执行结果如下:

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

select * from dept a left join (select deptno,count(*) from emp group by deptno) b on a.deptno=b.deptno;

执行结果如下:

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

select job,min(sal) from emp group by job;

执行结果如下:

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

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

执行结果如下:

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

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

执行结果如下:

19、查询雇员表中,姓名为SMITH的雇员,截止到今天共工作了多少周,则可以使用如下的SQL语句。

select round((sysdate-hiredate)/7) as "Weeks" from emp where ename='SMITH';

执行结果如下:

20、查询各部门的最高薪水、最低薪水、平均薪水…

select deptno,max(sal),min(sal),avg(sal) from emp group by deptno;

执行结果如下:

oracle练习题-emp表相关推荐

  1. oracle数据库emp表的内容,oracle数据库emp表

    Oracle 数据库视图与基表的关系 一:首先解释什么是视图:视图其实就是一条查... Oracle数据库Sql语句详解大全 第一章 SELECT查询 2021/2/4... n3等组成的二进制转变成 ...

  2. oracle习题-emp表查询练习

    emp表查询练习 1 查询emp表的全部记录 Select * from emp; 2 查询出每个雇员的编号.姓名.基本工资 Select empno,ename,sal from emp; 3 查询 ...

  3. oracle 创建emp表,dept表

    废话不多说 直接上SQL /*创建empz表*/ CREATE TABLE EMP (EMPNO NUMBER(4) NOT NULL, ENAME VARCHAR2(10), JOB VARCHAR ...

  4. Oracle针对EMP表的练习题(很有用,值得收藏)

    1.查询所有的部门编号: select DEPTNO from DEPT ; 2.查询所有有人的部门编号: select DEPTNO from EMP ; 3.查询所有岗位名称: select DI ...

  5. oracle创建emp表dept 表

    – 创建表与数据 CREATE TABLE EMP (EMPNO NUMBER(4) NOT NULL, ENAME VARCHAR2(10), JOB VARCHAR2(9), MGR NUMBER ...

  6. Oracle的emp表的基本函数学习

    --1. 找出各月倒数第3天受雇的所有员工 select * from empwhere to_char(hiredate,'dd')=to_char(last_day(hiredate),'dd') ...

  7. oracle数据库【表复制】insert into select from跟create table as select * from 两种表复制语句区别...

    create table  as select * from和insert into select from两种表复制语句区别 create table targer_table as select ...

  8. oracle数据库中emp表,根据Oracle数据库scott模式下的emp表和dept表

    Oracle数据库scott模式下的emp表和dept表的搜索练习,仅供参考 题目要求:根据Oracle数据库scott模式下的emp表和dept表,完成下列操作. (1) 查询20号部门的所有员工信 ...

  9. Oracle创建scott用户导入数据查看emp表

    写在前面,这里我使用的是database19c, 而从12c开始oracle就不再提供已经创建好的scott用户,所以我们需要自行创建来测试. 流程: 过程十分简单,大概两三分钟就能做好 打开cmd, ...

最新文章

  1. vue 动态生成路由菜单(从后端请求到菜单数据,生成左侧菜单栏)
  2. Generative Adversarial Text to Image Synthesis --- 根据文字描述生成对应的图片
  3. 对于asp.net服务器推送和客户端拉拽技术知识讲述
  4. Linux用php上传表单文件,文件太大提示[413 Request Entity Too Large]
  5. java动态代理_Java核心 -- 动态代理
  6. ETF的战争从未停止【文献推荐·天风金工吴先兴团队】
  7. Linux下怎么刷显卡bios,nvidia显卡如何刷bios?nvidia显卡刷bios教程
  8. QThread 线程终止
  9. 计算机专业考研好还是就业好?
  10. 算法分析稳定匹配问题c语言,算法-稳定匹配StableMatching
  11. 记录:java实时回传大疆无人机的视频和音频,低延时,稳定高效,可以对接飞行数据、经纬度信息、飞行轨迹等
  12. 微分中值定理—罗尔中值定理
  13. 查询注册表的命令行工具reg
  14. java支持库 易语言_易语言支持库简单安装加载添加
  15. 吸引力法则——宇宙的秘密
  16. 【PostgreSQL】PG中日期格式化与Java中的区别
  17. 3个月成功上岸中科大MBA切身经历
  18. linux密码验证机制,linux用户认证机制
  19. Linux系统调用全过程详解
  20. java 设计模式之Bridge

热门文章

  1. 利用Python爬取朋友圈数据,爬到你开始怀疑人生
  2. CMU开设美国首个人工智能本科专业
  3. 公司产品介绍PPT参考
  4. UnityVR--小程序7--坦克对战
  5. 通州区机器人比赛活动总结_2019年通州区中小学生机器人智能大赛举行
  6. 阿里云服务器ECS 第三篇:Oracle 数据库环境搭建
  7. 3步了解APP渠道应该怎样建设评估体系(上)
  8. V2X、OBU、RSU、V2V之间的协作关系
  9. 经典案例:卖票问题【线程同步】
  10. lang:C++自定义异常类——用来处理自制编程语言的异常信息