`
kuaile863
  • 浏览: 115775 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

oracle常见的经典查询语句(一)

阅读更多

01.       查询员工表所有数据

 

 select * from emp;

 

02.  查询职位(JOB)'PRESIDENT'的员工的工资

 

select sal from emp where job='PRESIDENT';

 

03.  查询佣金(COMM)0或为NULL的员工信息

 

 SQL> select * from emp where nvl(comm,0)=0;

 

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

 

select * from emp where hiredate between to_date('1981-5-1','YYYY-MM-DD') and to_date('1981-12-31','YYYY-MM-DD');

 

select * from emp where hiredate between to_date('1/5/1981') and to_date('31/12/1981');

 

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

 

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

 

06.  显示10号部门的所有经理('MANAGER')20号部门的所有职员('CLERK')的详细信息

 

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

 

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

 

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

 

08.  显示各个部门经理('MANAGER')的工资

 

select sal from emp where job='MANAGER';

 

09.  显示佣金(COMM)收入比工资(SAL)高的员工的详细信息

 

select * from emp where nvl(comm,0)>nvl(sal,0);

 

10.  hiredate列看做是员工的生日,求本月过生日的员工(考察知识点:单行函数)

 

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年入职的员工(考察知识点:单行函数)

 

      select * from emp where to_char( hiredate,'YYYY')=1982;

 

13.  1981年下半年入职的员工(考察知识点:单行函数)

 

SQL>  select * from emp where  to_char( hiredate,'YYYY-MM-DD') between '1981-07-01' and '1981-12-31' ;

 

14.  1981年各个月入职的的员工个数(考察知识点:组函数)

 

SQL>  select count(*),trunc(hiredate,'month')  from emp where to_char( hiredate,'YYYY')='1981' group by trunc(hiredate,'month') ;

 

 

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

 

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

select deptno,sum(nvl(sal,0)+nvl(comm,0))/count(*) from emp group by deptno;

 

 

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

 

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

 

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

 

SQL> select * from emp order by hiredate desc;

 

04.  查询员工的基本信息,附加其上级的姓名

 

SQL> select t1.empno,t1.ename,t1.job,t2.ename,t1.hiredate,t1.sal,t1.comm,t1.deptno from emp t1 join emp t2 on t1.mgr=t2.empno;

 

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

 

SQL> select t1.empno,t1.ename,t1.job,t1.mgr,t1.hiredate,t1.sal,t1.comm,t1.deptno from emp t1 join emp t2 on nvl(t1.sal,0)> nvl

(t2.sal,0) where t2.ename='ALLEN';

 

06.  显示与'SCOTT'从事相同工作的员工的详细信息

 

 SQL> select t1.empno,t1.ename,t1.job,t1.mgr,t1.hiredate,t1.sal,t1.comm,t1.deptno from emp t1 join emp t2 on t1.job=t2.job where t2.ename='SCOTT';

 

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

 

select ename from emp e, dept d where e.deptno = d.deptno and d.dname='SALES';

 

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

 

SQL> select e.* from emp e join emp e1 on e.sal=e1.sal where e.deptno=30 and e1.ename='MARTIN';

 

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

 

Select * from emp where sal>(select avg(nvl(sal,0)) from emp ) and job='SALESMAN';

 

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

 

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

 

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

 

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

 

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

 

               Select deptno,count(*) from emp group by deptno;

 

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

 

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

 

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

 

SQL> select t1.empno,t1.ename,t1.job,t1.mgr,t1.hiredate,t1.sal,t1.comm,t1.deptno from emp t1 join emp t2 on t1.sal=t2.sal where t1.empno!=t2.empno ;

 

15.  查询工资最高的 3名员工信息

 

 select   *   from   (select   *   from   emp   order   by   nvl(sal,0)   desc)   where   rownum<=3;

 

16.  按工资进行排名,排名从1开始,工资相同排名相同(如果两人并列第1则没有第2,从第三名继续排)

 

SQL> select e.*, (select count(*) from emp where nvl(sal,0)> nvl(e.sal,0))+1 rank from emp e order by rank;

 

17.  求入职日期相同的(年月日相同)的员工

 

SQL> select t1.empno,t1.ename,t1.job,t1.mgr,t1.hiredate,t1.sal,t1.comm,t1.deptno from emp t1 join emp t2 on t1.hiredate=t2.hiredate where t1.empno!=t2.empno ;

 

18.  查询每个部门的最高工资

 

 Select max(nvl(sal,0)),deptno from emp group by deptno;

 

19.  查询每个部门,每种职位的最高工资

 

select deptno, job, max(nvl(sal,0)) from emp group by deptno,job;

 

20.  查询每个员工的信息及工资级别(用到表 Salgrade)

 

SQL> select GRADE,e.* from salgrade , (Select * from  emp  ) e where  LOSAL <= nvl(e.sal,0) and nvl(e.sal,0)<=HISAL;

 

21.  查询工资最高的第 6-10 名员工

 

SQL> select * from (select e.*,rownum as rowno from (select   *   from   emp   order   by   nvl(sal,0)   desc) e) where rowno between 6 and 10;

 

22.  查询各部门工资最高的员工信息

 

Select * from emp e,(Select deptno,max(nvl(sal,0)) sa from emp group by deptno) s where e.sal=s.sa;

 

23.  查询每个部门工资最高的前 2名员工

 

SQL> select * from emp e where  (select count(*) from emp where nvl(sal,0) > nvl(e.sal,0) and e.deptno = deptno) < 2  order by deptno, nvl(sal,0) desc;

 

 

 

 

24.  查询出有3个以上下属的员工信息

 

 

 

SQL> select * from emp,(select mgr from (select mgr,count(*) from emp  group by mgr having count(*)>=3)) s where empno =s.mgr  ;

 

select * from emp e where  (select count(*) from emp where e.empno = mgr) > 2;

 

25.  查询所有大于本部门平均工资的员工信息() 

 

select * from emp e where sal > (select avg(sal) from emp where e.deptno=deptno) ;

 

26.  查询平均工资最高的部门信息

 

Select * from dept d,(Select deptno from (Select avg(nvl(sal,0)) sal ,deptno from emp group by deptno order by sal desc ) where   rownum<=1) e where d.deptno= e.deptno;

 

27.  查询大于各部门总工资的平均值的部门信息

 

 

select d.*,sumsal from dept d, (select sum(nvl(sal,0)) sumsal, deptno from emp group by deptno) se where se.sumsal >(select avg(sum(nvl(sal,0))) from emp group by deptno) and se.deptno = d.deptno;

 

28.  查询大于各部门总工资的平均值的部门下的员工信息(考察知识点:子查询,组函数,连接查询)

 

 select e.*,sumsal from emp e, (select sum(nvl(sal,0)) sumsal, deptno from emp group by deptno) se where se.sumsal >(select avg(sum(nvl(sal,0))) from emp group by deptno) and se.deptno = e.deptno;

 

29.  查询没有员工的部门信息

 

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

 

30.  查询用户(users表)huxz 所下所有订单编号,下单日期,总价格(orders),并包括订单中的商品数量(orderitem表),名称(product 表),价格(product表)

 

Select pr.PRODUCTNAME,qty,pr.PRODUCTID,orei,od,tp  from product pr, (Select QTY qty,PRODUCTID,ore.ORDERID orei,od,tp from orderitem  oi, (Select ORDERDATE od, ORDERID  , TOTALPRICE tp from orders where username=(select username from users where username='huxz') ) ore where ore.ORDERID= oi.ORDERID) ori where ori.PRODUCTID=pr.PRODUCTID;

 

31.  查询100001号商品被哪些顾客(users表)购买过,下单日期(orders),每人购买的数量(orderitem表),购买时的价格(product表)

 

Select ORDERDATE , TOTALPRICE, ords, qty   from  orders ors,(Select  ORDERID, QTY qty, ORDERID ords from  orderitem ord,( select PRICE from product where PRODUCTID='100001') where ord.PRODUCTID='100001' )  where ors.ORDERID= ords;

 

32.  查询出哪些商品从未被订购过

 

select * from product pro left join (select distinct PRODUCTID from orderitem) ord on pro.PRODUCTID=ord.PRODUCTID where ord.PRODUCTID is null;

 

33.  查询出被订购过 2次以上的商品信息

 

select p.* from product p where (select count(*) from orderitem where productid = p. productid) >= 2;

 

 

1
0
分享到:
评论

相关推荐

    Oracle报表经典语句

    本文档将深入解析几个经典的Oracle报表SQL语句,这些语句涉及到了Oracle中的高级功能,如窗口函数、联合查询等,并通过实际案例展示了如何构造报表。 #### 二、SQL语句分析 ##### 1. 分类汇总与总计 此段代码展示...

    经典的ORACLE查询语句教学资料

    在IT领域,数据库管理是至关重要的,而Oracle作为全球广泛使用的数据库管理系统,其查询语言SQL(Structured Query Language)更是IT专业人员必须掌握的核心技能之一。本教学资料专注于Oracle查询语句,结合MySQL、...

    oracle备份与经典语句

    以上就是关于“Oracle备份与经典语句”的主要知识点,涵盖了Oracle备份的重要性、类型、语句及恢复策略。了解并掌握这些内容,对Oracle数据库管理员来说至关重要,能有效保护数据安全,确保业务正常运行。

    ORACLE经典常用语句总结

    在IT领域,尤其是在数据库管理与开发中,Oracle作为一款广泛使用的数据库管理系统,其经典常用的SQL语句对于数据库管理员(DBA)以及开发人员而言至关重要。本文将深入解析Oracle中的关键SQL语句,涵盖表约束、索引...

    Oracle经典SQL语句

    ORACLE经典语句汇总 -- 字符串左填充和右填充,默认填充空格 -- 产生1~99行数据,少于一位则补0 -- 刪除相同行 -- 随机数 -- 产生业务流水号 -- 查询某张表中有哪些字段 -- 自循环表中 由叶子节点查父节点 -- 查子...

    oracle关于日期的查询语句

    本篇将深入探讨Oracle关于日期的查询语句及其相关知识点。 1. 数据类型: Oracle提供了多种日期和时间数据类型,包括DATE、TIMESTAMP、TIMESTAMP WITH TIME ZONE以及TIMESTAMP WITH LOCAL TIME ZONE。其中,DATE...

    ORACLE__SQL语句教学(附有sql最常用经典语句)

    本资源"ORACLE__SQL语句教学(附有sql最常用经典语句)"显然是一个针对Oracle SQL的深入学习资料,旨在帮助数据库编程者提升技能,成为真正的高手。 首先,让我们来看看SQL的基本概念。SQL是一种用于管理关系型...

    oracle 数据库46道经典查询

    根据给定文件的信息,我们可以梳理出46道经典的Oracle数据库查询题目所涉及的关键知识点,包括基本的表结构设计、数据插入以及复杂的SQL查询语句。下面将详细介绍这些知识点。 ### 表结构设计 #### 学生表...

    Oracle经典语句

    ### Oracle经典语句详解 #### 1. Oracle安装初始账号密码 在安装Oracle数据库时,系统会自动创建一些默认的用户账号,这些账号对于管理数据库至关重要。常见的几个默认账号包括: - **internal/oracle**: 这是...

    oracle常用经典语句

    一、Oracle常用经典语句 1. 数据查询:SQL(Structured Query Language)是与数据库交互的语言基础,包括SELECT语句用于数据查询。例如,查询所有员工的信息: ```sql SELECT * FROM employees; ``` 2. 数据插入:...

    Oracle经典建表语句

    本文档将详细介绍两个Oracle经典建表语句案例:`DHC_BY_GOODSBUY`表与`DHC_BY_GOODSBUYTOTAL`表的创建过程,并额外解析一个与之相关的`DHC_BY_GOODSBUY_OPINION`表的创建方法。通过这些实例,我们可以更好地理解...

    oracle常用经典sql查询

    本资源“oracle常用经典sql查询”汇集了Oracle环境中的一些常见且实用的SQL查询语句,帮助用户提高数据库操作效率。以下是对这些经典查询语句的详细解读: 1. **基本查询操作** - `SELECT * FROM table_name;`:这...

    20个Oracle经典面试查询语句

    保证你面试绝对会用到的SQL查询语句,快准备下吧

    oracle常用经典sql查询.rar

    本压缩包“oracle常用经典sql查询.rar”显然是一份关于如何在Oracle环境中高效运用SQL查询的教程资料,适合数据库管理员、开发人员以及对Oracle数据库感兴趣的用户学习。 首先,我们来探讨SQL的基础概念。SQL,全称...

    oracle最经典查询练习题及答案

    这是一个采用Oracle数据库自带的表的查询语句的一个非常好的练习,其中包括了一些简单的查询,已经具有Oracle自身特点的单行函数的应用,非常值得一看.

Global site tag (gtag.js) - Google Analytics