热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

oracle练习题emp表

–用SQL完成以下问题列表:–1.列出至少有一个员工的所有部门。–2.列出薪金比“SMITH”多的所有员工。–3.列出所有员工的姓名及其直接上级的姓名。–4.
–用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&#61;a.mgr);

执行结果如下&#xff1a;
在这里插入图片描述
5、列出部门名称和这些部门的员工信息&#xff0c;同时列出那些没有员工的部门。

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&#61;b.deptno;

执行结果如下&#xff1a;
在这里插入图片描述
6、列出所有“CLERK”(办事员)的姓名及其部门名称。

select a.ename,b.dname from emp a join dept b on a.deptno&#61;b.deptno and a.job&#61;&#39;CLERK&#39;;

执行结果如下&#xff1a;
在这里插入图片描述
7、列出最低薪金大于1500的各种工作。

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

执行结果如下&#xff1a;
在这里插入图片描述
8、列出在部门“SALES”(销售部)工作的员工的姓名&#xff0c;假定不知道销售部的部门编号。

select ename from emp where deptno&#61;(select deptno from dept where dname&#61;&#39;SALES&#39;);

执行结果如下&#xff1a;
在这里插入图片描述
9、列出薪金高于公司平均薪金的所有员工。

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

执行结果如下&#xff1a;
在这里插入图片描述
10、列出与“SMITH”从事相同工作的所有员工。

select ename from emp where job&#61;(select job from emp where ename&#61;&#39;SMITH&#39;);

执行结果如下&#xff1a;
在这里插入图片描述
11、列出薪金等于部门30中员工的薪金的所有员工的姓名和薪金。

select ename,sal from empwhere sal in (select sal from emp where deptno&#61;30);

执行结果如下&#xff1a;
在这里插入图片描述
12、列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金。

select ename,sal from emp where sal>(select max(sal) from emp where deptno&#61;30);

执行结果如下&#xff1a;
在这里插入图片描述
13、列出在每个部门工作的员工数量、平均工资和平均服务期限。

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

执行结果如下&#xff1a;
在这里插入图片描述
14、列出所有员工的姓名、部门名称和工资。

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

执行结果如下&#xff1a;
在这里插入图片描述
15、列出所有部门的详细信息和部门人数。

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

执行结果如下&#xff1a;
在这里插入图片描述
16、列出各种工作的最低工资。

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

执行结果如下&#xff1a;
在这里插入图片描述
17、列出各个部门的MANAGER(经理)的最低薪金。

select deptno,min(sal) from emp where job&#61;&#39;MANAGER&#39; group by deptno;

执行结果如下&#xff1a;
在这里插入图片描述
18、列出所有员工的年工资,按年薪从低到高排序。

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

执行结果如下&#xff1a;
在这里插入图片描述
19、查询雇员表中&#xff0c;姓名为SMITH的雇员&#xff0c;截止到今天共工作了多少周&#xff0c;则可以使用如下的SQL语句。

select round((sysdate-hiredate)/7) as "Weeks" from emp where ename&#61;&#39;SMITH&#39;;

执行结果如下&#xff1a;
在这里插入图片描述
20、查询各部门的最高薪水、最低薪水、平均薪水…

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

执行结果如下&#xff1a;
在这里插入图片描述


推荐阅读
  • 本文介绍了 Oracle SQL 中的集合运算、子查询、数据处理、表的创建与管理等内容。包括查询部门号为10和20的员工信息、使用集合运算、子查询的注意事项、数据插入与删除、表的创建与修改等。 ... [详细]
  • 在运行于MS SQL Server 2005的.NET 2.0 Web应用中,我偶尔会遇到令人头疼的SQL死锁问题。过去,我们主要通过调整查询来解决这些问题,但这既耗时又不可靠。我希望能找到一种确定性的查询模式,确保从设计上彻底避免SQL死锁。 ... [详细]
  • 本文详细介绍了Oracle 11g中的创建表空间的方法,以及如何设置客户端和服务端的基本配置,包括用户管理、环境变量配置等。 ... [详细]
  • 如何将955万数据表的17秒SQL查询优化至300毫秒
    本文详细介绍了通过优化SQL查询策略,成功将一张包含955万条记录的财务流水表的查询时间从17秒缩短至300毫秒的方法。文章不仅提供了具体的SQL优化技巧,还深入探讨了背后的数据库原理。 ... [详细]
  • 本文详细介绍了PostgreSQL与MySQL在SQL语法上的主要区别,包括如何使用COALESCE替代IFNULL、金额格式化的方法、别名处理以及日期处理等关键点。 ... [详细]
  • 本文介绍了如何在两个Oracle数据库(假设为数据库A和数据库B)之间设置DBLink,以便能够从数据库A中直接访问和操作数据库B中的数据。文章详细描述了创建DBLink前的必要准备步骤以及具体的创建方法。 ... [详细]
  • 本文详细介绍了Hibernate中的立即检索与延迟检索的概念及区别,同时探讨了类级别与关联级别的检索配置方法。通过具体的配置示例,帮助开发者更好地理解和应用这些策略。 ... [详细]
  • PHP面试题精选及答案解析
    本文精选了新浪PHP笔试题及最新的PHP面试题,并提供了详细的答案解析,帮助求职者更好地准备PHP相关的面试。 ... [详细]
  • 本文介绍了几个关于SQL查询中列使用的优化规则,包括避免使用SELECT *、指定INSERT列名、修改自增ID为无符号类型、为列添加默认值以及为列添加注释等。 ... [详细]
  • 本文介绍了 PHP 的基本概念、服务器与客户端的工作原理,以及 PHP 如何与数据库交互。同时,还涵盖了常见的数据库操作和安全性问题。 ... [详细]
  • 本文详细介绍了如何在 Oracle 数据库中进行筛选备份和恢复操作,包括权限授予、目录管理、数据导出和导入等步骤。 ... [详细]
  • 本文介绍了如何在 SQL Server (MSSQL) 数据库中更新 XML 列中的属性和节点内容。 ... [详细]
  • 本文介绍了一种使用SQL Server存储过程来实现基于单一条件的高效分页查询的方法。通过示例代码,详细说明了如何构建和执行这种分页查询。 ... [详细]
  • 如何在Django框架中实现对象关系映射(ORM)
    本文介绍了Django框架中对象关系映射(ORM)的实现方式,通过ORM,开发者可以通过定义模型类来间接操作数据库表,从而简化数据库操作流程,提高开发效率。 ... [详细]
  • JUnit下的测试和suite
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
author-avatar
我是小钞票
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有