说明:表数据来自oracle 初始用户之一scott里面的三个初始表:emp,dept,salgrade

--1、查询员工表中工资最高的雇员的员工号、员工姓名、工资和部门号。

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

--2、薪水大于1200的雇员,按照部门编号进行分组,分组后平均薪水必须大于1500,查询各分组的平均水平,按照工资的倒序进行排列。

select deptno,avg(sal) from emp where sal>1200 group by deptno having avg(sal)>1500 order by avg(sal) desc;

--3、查询每个雇员和其所在部门名、按照员工名字排序,要求值显示第三条到第六条记录

--     rownum是伪列,rownum>2,没有查询到任何记录。
-- 因为rownum总是从1开始的,第一条不满足去掉的话,第二条的rownum 又成了1。依此类推,所以永远没有满足条件的记录。
-- 可以这样理解:rownum是一个序列,是Oracle数据库从数据文件或缓冲区中读取数据的顺序
select * from
(select emp.ename,dname,rownum rn from emp,dept where emp.deptno=dept.deptno and rownum<=6 order by emp.ename )--必须是内小于外大于
where rn>=3;
-- 内连接 只返回两个表中连接字段相等的行。
select ename,dname from emp inner join dept on emp.deptno = dept.deptno;
-- 第二种方式
select * from
(select emp.ename,dname,rownum rn from emp,dept where emp.deptno=dept.deptno order by emp.ename )
where rn between 3 and 6; -- 第三种
select * from(
select t.*, rownum rn from(
select ename,dname from emp inner join dept on emp.deptno = dept.deptno order by emp.ename
) t where rownum<=6
) where rn>=3;

-- 4、查询每个雇员姓名以及工资所在的等级。

--第一种
select ename,sal,grade from emp,salgrade where sal between losal and hisal; --第二种 内连接
select ename,sal,grade from emp inner join salgrade on sal between losal and hisal;

--5、查询雇员名第二个字母不是a的雇员的姓名、所在的组名、工资所在的等级

--第一种
--用substr分割截取字符串
select ename,dname,grade from emp,dept,salgrade
where sal between losal and hisal and emp.deptno=dept.deptno and substr(ename,2,1) !='a' and substr(ename,2,1) !='A'; --第二种
--内连接 模糊查询,第一个下划线代表第一个字符
select ename,dname,grade
from emp inner join dept on dept.deptno=emp.deptno
inner join salgrade on sal between losal and hisal
where ename not like '_A%';

--6、查询每个雇员和其经理的姓名

--第一种 使用自连接
select e1.ename empname,e2.ename mgrname from emp e1,emp e2
where e1.mgr=e2.empno;
--第二种 自连接与内连接
select e1.ename empname,e2.ename mgrname
from emp e1 inner join emp e2
on e1.mgr=e2.empno;

--7、查询每个雇员和其经理的姓名(包括公司老板本身(他上面没有经理));

--左连接,左表中所有记录()以及右表中连接字段相等的记录
select e1.ename empname,e2.ename mgrname from emp e1 left join emp e2 on e1.mgr=e2.empno;

--8、查询每个雇员的姓名及其所在部门的部门名(包括没有雇员的部门)

--右连接,油表中所有记录()以及右表中连接字段相等的记录
select ename,dname from emp right join dept on emp.deptno=dept.deptno;

--9、查询每个部门中工资最高的人的姓名、薪水和部门编号。

--把查询变成一个子表
--group by要包含所有选择的字段(除了函数的),所以先查询出每个部门最高工资,然后和原始表关联,就可以查出部门最高工资者的所有信息
select ename,sal,emp.deptno from emp
inner join
(select deptno,max(sal) msal from emp group by deptno) maxsalresult
on maxsalresult.deptno=emp.deptno and sal=maxsalresult.msal;

--10、查询每个部门平均工资所在的等级

select deptno,grade,avgsalresult.avgsal avragesal
from salgrade inner join
(select avg(sal) avgsal,deptno from emp group by deptno) avgsalresult
on avgsal between losal and hisal;

oracle 查询 10题的更多相关文章

  1. 45 个非常有用的 Oracle 查询语句

    ​ 这里我们介绍的是 40+ 个非常有用的 Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询.这些是所有 Oracle 开发者都必备的技能,所以快 ...

  2. oracle 查询最近执行过的 SQL语句(转载)

    oracle 查询最近执行过的 SQL语句 (2014-06-09 18:02:43) 转载▼   分类: Database oracle 查询最近执行过的 SQL语句 select sql_text ...

  3. oracle 查询最近执行过的 SQL语句

    oracle 查询最近执行过的 SQL语句 select sql_text,last_load_time from v$sql order by last_load_time desc;   SELE ...

  4. Oracle查询被锁的表及进程的方法

    Oracle查询可以有多种方法,下面为您介绍的是如何Oracle查询被锁的表及Oracle查询连接的进程的方法,希望对您能够有所帮助. 一.查看被锁的表 select p.spid,a.serial# ...

  5. 40多个非常有用的Oracle 查询语句

    给大家介绍是40多个非常有用的Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询.这些是所有Oracle 开发者都必备的技能,所以快快收藏吧! 日期 ...

  6. 45个非常有用的 Oracle 查询语句小结

    45个非常有用的 Oracle 查询语句小结 这里我们介绍的是 40+ 个非常有用的 Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询.这些是所有 ...

  7. 45 个非常有用的 Oracle 查询语句(转)

    这里我们介绍的是 40+ 个非常有用的 Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询.这些是所有 Oracle 开发者都必备的技能,所以快快收 ...

  8. Oracle查询速度慢的原因总结

    Oracle查询速度慢的原因总结 查询速度慢的原因很多,常见如下几种:1,没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷)2,I/O吞吐量小,形成了瓶颈效应.3,没有创建计算列导致 ...

  9. 40+ 个非常有用的 Oracle 查询语句

    40+ 个非常有用的 Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询.这些是所有 Oracle 开发者都必备的技能,所以快快收藏吧! 日期/时间 ...

随机推荐

  1. [转]无法解析的外部符号 _main,该符号在函数 ___tmainCRTStartup 中被引用

    刚学WinAPI编译遇到不少问题,LNK2019: 无法解析的外部符号 _main,该符号在函数 ___tmainCRTStartup 中被引用 MSVCRTD.lib test. 这个问题表明你新建 ...

  2. 微信小程序上传单张或多张图片

    -- chooseImage: function () { let that = this; let worksImgs = that.data.worksImgs; let len = that.d ...

  3. 【转】使用AllureReport生成测试报告

    Allure简介 Allure是一个report框架,可以基于一些测试框架生成测试报告,比较常用的一般是Junit/Testng框架:Allure 生成的报告样式简洁美观,同时又支持中文:Allure ...

  4. Android近场通信---NFC基础转)

    Android近场通信---NFC基础(一)(转) 本文介绍在Android系通过你所能执行的基本任务。它解释了如何用NDEF消息格式来发送和接收NFC数据,并且介绍了支持这些功能的Android框架 ...

  5. Eclipse导入工程提示“No projects are found to import”

    如果发现导入工程的时候,出现"No projects are found to import" 的提示,首先查看项目目录中是否有隐藏文件.project,还有目录结构也还要有一个隐 ...

  6. 成为真正的win10 超级管理员,解决win+r 不以管理员身份运行

    secpol.msc 本地策略=>安全选项 禁用 用户账户控制:以管理员批准模式运行所有管理员 用户帐户控制:用于内置管理员帐户的管理员批准模式 注意:需要重启计算机

  7. 如何在LabWIndows/CVI中调用LabVIEW DLL

    首先请参考官方的文档 http://digital.ni.com/public.nsf/websearch/70995EC2CA1B523386256DD4004F3DE6?OpenDocument ...

  8. Vue 引入 .md 文件,解析markdown语法

    module.exports = { chainWebpack: config => { config.module .rule('md') .test(/\.md$/) .use('html- ...

  9. [LeetCode] 106. Construct Binary Tree from Inorder and Postorder Traversal 由中序和后序遍历建立二叉树

    Given inorder and postorder traversal of a tree, construct the binary tree. Note:You may assume that ...

  10. [LeetCode] 163. Missing Ranges 缺失区间

    Given a sorted integer array nums, where the range of elements are in the inclusive range [lower, up ...