当前位置:  数据库>oracle

Oracle查询语句面试题

    来源: 互联网  发布时间:2017-04-24

    本文导语: 01. 查询员工表所有数据,并说明使用*的缺点 select * from emp; 01.查询职(job)为'PRESIDENT'的员工的工资 select sal from emp where job='PRESIDENT'; 02.查询佣金为0或为null的员工的信息 select * from emp where comm is null or comm=1; 03...

01. 查询员工表所有数据,并说明使用*的缺点

select * from emp;

01.查询职(job)为'PRESIDENT'的员工的工资

select sal from emp where job='PRESIDENT';

02.查询佣金为0或为null的员工的信息

select * from emp where comm is null or comm=1;

03.查询入职日期在1981-5-1到1981-12-31之间的所有员工的信息

select * from emp where hiredate between to_date(‘1-5月-81’) and to_date(‘31-12月-81’)

04..查询所有名字长度为4的员工的员工的编号,姓名

select empno,ename from emp where length(ename)=4

05.显示10号部门饿所有经理和20号部门的所有员工

select * from emp where job='MANAGER' and deptno=10 or job='CLERK' and deptno=20;

06.显示姓名没有'L'字的员工的详细信息或含有'SM'字的员工信息

select * from emp where ename not like '%L%' or ename like '%SM%';

07.显示各个部门经理的工资

select deptno,sal from emp where job='MANAGER';

08.显示佣金收入比工资高的员工的详细信息

select * from emp where comm>sal;

10.把hiredate列看做是员工的生日,求本月过生日的员工:

SQL> select * from emp

where to_char(hiredate,'mm')=to_char(sysdate,'mm');

11.把hiredate列看做是员工的生日,求下月过生日的员工

SQL> select * from emp

where to_char(hiredate,'mm')=to_char(add_months(sysdate,1

),'mm');

12.求1982年入职的员工

SQL> select * from emp where to_char(hiredate,'yyyy')='1982';

hiredate是date类型的,1982是字符串类型的,类型匹配才可以

13.求1981年下半年入职的员工

select * from emp

where hiredate between to_date('1981-7-1','yyyy-mm-dd')

and to_date('1982-1-1','yyyy-mm-dd')-1;

注:to_char()函数和to_date()函数

to_char()函数是把日期的类型转换为指定的格式

to_date()是把字符串转换为日期类型

-1的原因是更精确

14.求1981年各个月入职的员工个数

SQL> select to_char(hiredate,'mm'),count(*) from emp where to_char(hiredate,'yyy

y')='1981' group by to_char(hiredate,'mm') order by to_char(hiredate,'mm');

select to_char(hiredate,'mm'),count(*) from emp where to_char(hiredate,'yyyy')='1981' group by to_char(hiredate,'mm') order by to_char(hiredate,'mm');

PartII

01  .查询各个部门的平均工资

SQL> select deptno,avg(nvl(sal,0)) from emp group by deptno;

02.显示各种职位的最低工资

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

03.按照入职日期由新到旧排列员工信息

SQL> select hiredate from emp order by hiredate desc;

04.查询员工的基本信息,附加其上级的姓名(自关联)

SQL> select e.*,e1.ename from emp e,emp  e1 where e.mgr=e1.empno;

05.显示工资比’ALLEN’高的所有员工的姓名和工作

SQL> select ename,sal from emp where sal>(

select sal from emp where ename='ALLEN');

06.显示与scott从事相同工作的员工的信息(子查询

SQL> select * from emp where job=(

select job from  emp where ename='SCOTT');

07.显示销售部(‘SALES’)员工的姓名

SQL> select e.ename from emp e inner join dept d on e.deptno=d.deptno where d.dname='SALES';

08.显示与30号门’MARTIN’员工工资相同的员工的姓名和工资

SQL> select ename,sal from emp where sal=(select sal from emp where deptno=30 and ename='MARTIN');

09.查询所有工资高于平均工资(包括所有员工)的销售人员

SQL> select * from emp where sal>(

select avg(sal) from emp) and job='SALESMAN';

SQL> select * from emp where job='SALESMAN' and sal>(

select avg(sal) from emp);

10.显示所有职员的姓名及其所在部门的名称和工资(表连接)

SQL> select e.*,e.sal,d.dname from emp e inner join dept d on e.deptno=d.deptno;

11.查询在研发部(RESEARCH)工作人员的编号,姓名,工作部门,工作所在地

SQL> select e.empno,e.ename,d.dname,d.loc from emp e inner join dept d on e.deptno=d.deptno where dname='RESEARCH';

12.查询各个部门的名称和员工人数

select e.deptno,d.dname,count(*) from emp e inner join dept d on e.deptno=d.deptno group by e.deptno,d.dname

分析

SQL> select d.dname from emp e inner join dept d on e.deptno=d.deptno group by e.deptno,d.dname;

DNAME

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

ACCOUNTING

RESEARCH

SALES

SQL> select e.deptno,d.dname from emp e inner join dept d on e.deptno=d.deptno group by e.deptno,d.dname;

DEPTNO DNAME

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

10 ACCOUNTING

20 RESEARCH

30 SALES

SQL> select e.deptno,d.dname,count(*) from emp e inner join dept d on e.deptno=d.deptno group by e.deptno,d.dname;

DEPTNO DNAME            COUNT(*)

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

10 ACCOUNTING              3

20 RESEARCH                5

30 SALES                   6

13.查询各个部门员工工资大于平均工资(平均工资包括所有员工)的人数和员工职位(子查询)

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

14.查询工资相同的员工的工资和姓名(子查询)

SQL> select sal,ename from emp e where(select count(*) from emp where sal=e.sal group by sal)>1;

SQL> select e.sal,e.ename from emp e,emp e1 where e.sal=e1.sal and e.ename<>e1.ename;


    
 
 

您可能感兴趣的文章:

  • oracle导出sql语句的结果集和保存执行的sql语句(深入分析)
  • oracle用什么SQL语句判断表存不存在
  • 请问怎么用jsp语句删除oracle中的一条记录?
  • Oracle中SQL语句连接字符串的符号使用介绍
  • Oracle用什么语句查询字段?
  • 怎么在java中向一个sql语句传参数,就像oracle的proc一样啊?
  • 请问在 Linux 下如何用代码实现连接oracle数据库 并 执行 SQL 语句?
  • Oracle 9i轻松取得建表和索引的DDL语句
  • Oracle的SQL语句中如何处理‘&’符号
  • 关于Oracle中的sql语句的疑问,向大家请教。
  • Oracle Sql语句长度限制问题及解决
  • Oracle9i取得建表和索引的DDL语句
  • Oracle 中文字段进行排序的sql语句
  • oracle数据库添加或删除一列的sql语句
  • Oracle中查询本月星期5的所有日期列表的语句
  • Oracle中备份表的简单sql命令语句
  • oracle中误删除表后恢复语句(FLASHBACK)
  • Oracle判断指定列是否全部为数字的sql语句
  • jsp中在oracle中查询日期类型时sql语句该怎么写啊?
  • Oracle 常用的SQL语句
  • 了解学习国外公司的Oracle DBA面试试题
  • 开贴发“在redhat9下安装oracle9.2.0”的文档(前面试发过没发完就没看到了,重发),希望对大家有帮张
  • Oracle面试题及答案整理
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • Oracle查询出现异常
  • Oracle将查询的结果放入一张自定义表中并再查询数据
  • oracle+jsp 多用户查询系统讨论:
  • Oracle查询表、视图、序列等信息查询
  • 关于Oracle的查询问题
  • Oracle 查询指定表名的columns
  • linux下通过对文件读取方式查询oracle的版本信息
  • Oracle的大数据量查询结果显示问题。(高手帮忙)
  • Oracle对两个数据表交集的查询
  • Oracle数据库并行查询出错的解决方法
  • Oracle 合并查询
  • 查询与修改Oracle字符集
  • 紧急求救:jsp对Oracle数据库中long 型数据进行模糊查询 如何查?
  • oracle通过行范围查询取4至10行
  • mysql仿oracle的decode效果查询
  • 紧急求救:对Oracle数据库中long 型数据进行模糊查询 如何查?
  • oracle查询不含括号及不含指定字符的方法
  • Oracle 分页和排序常用的4条查询语句
  • 用Oracle动态性能视图采集查询调优数
  • ORACLE 如何查询被锁定表及如何解锁释放session
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • 虚拟机装Oracle R12与Oracle10g
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle 数据库开发工具 Oracle SQL Developer
  • Oracle 10g和Oracle 11g网格技术介绍
  • Oracle EBS R12 支持 Oracle Database 11g


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,