`
backspace
  • 浏览: 133695 次
文章分类
社区版块
存档分类
最新评论

Oracle操作实例

 
阅读更多

:所有部门。
select dept.deptno,dept.dname
from dept,emp
where dept.deptno=emp.deptno
2.列出薪金比“SMITH”多的所有员工。
select * from emp
where sal >(select sal from emp where ename=’SMITH’)
3.列出所有员工的姓名及其直接上级的姓名。
select yg.ename,sj.ename
from emp yg,emp sj
where yg.mgr=sj.empno

4.列出受雇日期早于其直接上级的所有员工。
select yg.ename,sj.ename
from emp yg join emp sj on yg.mgr=sj.empno
where yg.hiredate
5.列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。
select dept.deptno,dept.dname,emp.empno,emp.ename
from dept left join emp
on dept.deptno=emp.deptno
6.列出所有“CLERK”(办事员)的姓名及其部门名称。
select * from dept,emp
where dept.deptno=emp.deptno
and job=’CLERK’
7.列出最低薪金大于1500的各种工作。
select job from emp
group by job
having min(sal)>1500

8.列出在部门名称为“SALES”(销售部)工作的员工的姓名,假定不知道销售部的部门编号。
方法一:
select emp.ename
from dept,emp
where dept.deptno=emp.deptno
and dname=’SALES’
方法二:
select * from emp
where deptno=(select deptno from dept where dname=’SALES’)
9.列出薪金高于公司平均薪金的所有员工。
select * from emp
where sal> (select avg(sal) from emp)
对比:列出薪金高于本部门平均薪金的所有员工。
方法一:
select * from emp a
where a.sal>(select avg(sal) from emp b where b.deptno=a.deptno)
缺点:相关子查询,效率低。
方法二:
select empno,ename,sal from
emp a,(select avg(sal) avg_sal from emp b where b.deptno=a.deptno) b
where a.deptno=b.deptno
and a.sal>b.avg_sal
10.列出与“SCOTT”从事相同工作的所有员工。
select * from emp
where job=(select job from emp where ename=’SCOTT’)
11.列出薪金等于部门30中员工的薪金的所有员工的姓名和薪金。
select ename,sal from emp
where sal=any(select sal from emp where deptno=30 )

12.列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金。
方法一:
select ename,sal from emp
where sal>all(select sal from emp where deptno=30 )
方法二:
select ename,sal from emp
where sal>(select max(sal) from emp where deptno=30 )
13.列出在每个部门工作的员工数量、平均工资和平均服务期限。
select deptno,avg(trunc((sysdate-hiredate)/365)) as year
from emp
group by deptno
–参考:截断,取整函数
select trunc(99.9) from dual;
返回
99
14.列出所有员工的姓名、部门名称和工资。
select d.dname,e.ename,e.sal
from dept d,emp e
where d.deptno=e.deptno
说明:每个字段都加表前缀,效率要高些 
15.列出所有部门的详细信息和部门人数。
select dept.deptno,dept.dname,count(*)
from dept,emp
where dept.deptno=emp.deptno
group by dept.deptno,dept.dname

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 empno,ename,sal*12 as 年薪 from emp
order by sal
19. 求各种工作工资最低的员工。
方法一:
select * from emp a
where sal=(select min(sal) from emp b where b.job=a.job)
方法二:
select emp.*
from emp a,( select job,min(sal) min_sal from emp group by job) b
where a.job=b.job and a.sal=b.min_sal
20. 列出各种工作工资前3名的员工
select * from (
select empno,ename,sal,job,
dense_rank() over(partition by job order by sal desc) as 名次
from emp ) a
where a.名次<=2
order by job;
说明:用到了Oracle强大的“分区排名技术”,其中“dense_rank()”是Oracle的解析函数。

1
0
分享到:
评论

相关推荐

    oracle操作实例

    oracle,oracle操作实例,oracle函数,oracle知识

    通用语言实现Oracle操作实例.pdf

    通用语言实现Oracle操作实例.pdf

    oracle 数据库实例与操作模式

    oracle 数据库实例与操作模式

    oracle冷备份实例forwindows

    oracle 冷备份是指在 Windows 平台上对 Oracle 数据库实例进行备份的操作。冷备份需要将企业的 Oracle 数据库实例shutdown下来,并将所有的数据文件、控制文件、参数文件等拷贝回来,然后恢复。为确保备份的完整性...

    oracle数据库_实例_用户_表空间之间的关系

    Oracle 数据库的概念不同于其他数据库,它是一个操作系统只有一个库,可以看作是 Oracle 只有一个大数据库。 实例 Oracle 实例(Oracle Instance)是一组后台进程(Backguound Processes)和内存结构(Memory ...

    Oracle 19c 单实例 RU 从19.3.0 升级到19.6.0 操作手册.pdf

    Oracle 19c 单实例 RU 从19.3.0 升级到19.6.0 操作手册 Dave From CNDBA 社区

    ORACLE BIEE实例操作指南

    ORACLE BIEE实例操作指南,以实例介绍ORACLE BIEE 的操作方法与步骤

    oracle实例名,服务名等概念区别与联系

    ORACLE_SID 用于与操作系统交互,也就是说,从操作系统的角度访问实例名,必须通过 ORACLE_SID。 服务名 服务名是数据库的网络别名,用于在网络上访问数据库。服务名可以是数据库名或实例名,也可以是其他名称。...

    oracle基础教程vb示例

    oracle基础教程vb示例oracle基础教程vb示例oracle基础教程vb示例

    oracle实例内存(SGA和PGA)调整

    Oracle 实例内存(SGA 和 PGA)调整 Oracle 实例内存调整是 Oracle 数据库性能优化的重要方面。SGA(System Global Area)和 PGA(Process Global Area)是 Oracle 实例中的两个主要内存区域。本文将详细介绍 SGA 和 ...

    Oracle数据库基本操作实例

    关于oracle 数据库语言的基本操作,包括数据定义语句,数据操作语句和数据控制语句等。

    Python操作Oracle数据库的简单方法和封装类实例

    本文实例讲述了Python操作Oracle数据库的简单方法和封装类。分享给大家供大家参考,具体如下: 最近工作有接触到Oracle,发现很多地方用Python脚本去做的话,应该会方便很多,所以就想先学习下Python操作Oracle的...

    oracle 创建job实例

    Oracle 创建 Job 实例是指在 Oracle 数据库中创建一个计划任务,用于在特定的时间点执行特定的操作。以下是创建 Job 实例的详细过程和相关知识点: 一、创建 Job 实例 要创建一个 Job 实例,需要使用 dbms_job....

    实战管理Oracle 12c数据库实例

    实战管理Oracle 12c数据库实例 Oracle 12c数据库实例管理是 DBA 的核心工作之一,本文将从数据库版本号、参数对比、安装环境、启动数据库阶段等方面详细介绍实战管理Oracle 12c数据库实例的知识点。 1. 数据库...

    oracle对象创建实例

    对oracle数据库的操作经常会遇到trigger ,procude 等对象的创建,该文档是很有帮助的。

    oracle建表,实例,用户

    可以对Oracle数据库 创建表空间,实例,新建用户,以及授权操作手册。方便实用

    Oracle数据库实例的创建、删除与修改.docx

    Oracle 数据库实例是指一个动态概念,包括一些内存区域以及若干进程,数据库实例是对数据库进行操作的执行者。创建数据库实例是使用 Oracle 数据库系统的第一步。Oracle 提供了三种创建数据库实例的方法,本文将对...

    Oracle触发器 实例讲解

    Oracle 触发器实例讲解 Oracle 触发器是一种特定事件出现的时候,自动执行的代码块。类似于存储过程,但是用户不能直接调用他们。它主要有以下几个功能: 1. 允许/限制对表的修改:触发器可以控制对表的修改操作,...

    Oracle11G创建数据库实例

    Oracle11G创建数据库实例的过程截图,注意:在开始创建数据库实例之前要把oracle的监听服务OracleOraDb11g_home1TNSListner启动。否则,在创建的过程中会提示无法往下操作。

Global site tag (gtag.js) - Google Analytics