子查询和表连接

 ①.查询挣钱最多的人的名字

 SELECT ename,sal FROM emp

 WHERE sal=(SELECT MAX(sal) FROM emp);

 ②.查询有哪些人的工资位于全部人的平均工资之上

 SELECT ename,sal FROM emp

 WHERE sal > (SELECT AVG(sal) FROM emp);

 ③.求部门中哪些人的薪水最高:

 SELECT ename,sal FROM emp

 JOIN (SELECT MAX(sal) max_sal,deptno FROM emp GROUP BY deptno) t

 ON emp.sal =t.max_sal AND emp.deptno = t.deptno;

④.求出员工的名字和他的经理人姓名

  SELECT  e1.ename, e2.ename FROM

  emp e1 JOIN emp e2

  ON e1.mgr = e2.empno;

 ⑤.查询出每一个人的薪水等级

  SELECT ename,grade FROM emp e JOIN salgrade s

  ON  (e.sal BETWEEN s.losal AND s.hisal);

 ⑥查询出每一个人的部门名称和薪水等级

 SELECT ename,dname,grade FROM

 emp e JOIN dept d ON (e.deptno =d.deptno)

 JOIN salgrade s ON (e.sal BETWEEN s.losal AND s.hisal)

 ⑦(左外连接) 查询出雇员的名字和他经理人的名字

 SELECT e1.ename, e2.ename FROM

 emp e1 LEFT JOIN emp e2

 ON e1.mgr = e2.empno;

⑧(右外连接) 查询出全部雇员的部门名称

 SELECT ename ,dname FROM

 emp e RIGHT JOIN dept d

 ON e.deptno = d.deptno;

 ⑨(全外连接) 查询出全部雇员的部门名称

 SELECT ename ,dname FROM

 emp e FULL JOIN dept d

 ON e.deptno = d.deptno;

 ⑩求部门平均薪水的等级

 SELECT deptno,avg_sal,grade FROM

 (SELECT deptno,AVG(sal) avg_sal FROM emp GROUP BY deptno) t

 JOIN salgrade s

 ON t.avg_sal BETWEEN s.losal AND s.hisal;

--求部门平均的薪水等级

  SELECT deptno,AVG(grade) FROM

 (SELECT deptno,ename,grade FROM emp JOIN salgrade s ON

  emp.sal BETWEEN s.losal AND s.hisal) t

  GROUP BY deptno;

--求雇员中哪些人是经理人

 SELECT  ename FROM emp

 WHERE  empno  in(SELECT DISTINCT mgr FROM emp);

--不准用组函数,求薪水的最高值

  SELECT sal FROM emp WHERE sal NOT IN

 (SELECT DISTINCT  e1.sal FROM emp e1  JOIN  emp e2

 ON e1.sal< e2.sal);

--平均薪水最高的部门的部门编号

SELECT deptno ,avg_sal FROM

( SELECT deptno, AVG(sal) avg_sal FROM emp GROUP BY deptno);

WHERE avg_sal =

(SELECT MAX(avg_sal) FROM

( SELECT deptno, AVG(sal) avg_sal FROM emp GROUP BY deptno));

--平均薪水最高的部门的部门名称

SELECT dname FROM dept WHERE deptno =

(SELECT deptno  FROM

        ( SELECT deptno, AVG(sal) avg_sal FROM emp GROUP BY deptno)

 WHERE avg_sal =

(SELECT MAX(avg_sal) FROM

        ( SELECT deptno, AVG(sal) avg_sal FROM emp GROUP BY deptno)

  )

);



--求平均薪水的等级最低的部门的部门名称

SELECT dept.dname,t1.deptno,grade,avg_sal FROM

(

SELECT deptno,grade,avg_sal FROM

(SELECT AVG(sal) avg_sal, deptno FROM emp GROUP BY deptno) t JOIN salgrade s

ON t.avg_sal BETWEEN s.losal AND s.hisal

) t1

JOIN dept ON (t1.deptno = dept.deptno)

WHERE t1.grade =

(SELECT MIN(grade) FROM

(SELECT deptno,grade,avg_sal FROM

(SELECT AVG(sal) avg_sal, deptno FROM emp GROUP BY deptno) t JOIN salgrade s

ON t.avg_sal BETWEEN s.losal AND s.hisal))



--求部门经理人平均薪水最低的部门名称





--求比普通员工的最高薪水还要高的经理人名称

  SELECT ename  FROM emp WHERE

  empno IN (SELECT DISTINCT mgr FROM emp WHERE mgr IS NOT NULL)

  AND sal >

(SELECT max(sal) FROM  emp WHERE empno NOT  IN

(SELECT DISTINCT mgr FROM emp WHERE mgr IS NOT NULL))



--求薪水最高的前5名雇员

SELECT ename,sal

FROM (

SELECT ename,sal FROM emp ORDER BY sal DESC

)

WHERE ROWNUM <=5;

--求薪水最高的第6到第10名雇员

SELECT ename,sal FROM(

SELECT ename,sal, ROWNUM r FROM(

SELECT ename,sal FROM emp ORDER BY sal DESC)

)

WHERE r>=6 AND r<=10;

注:查询语句是自己看马士兵的视频敲出来的

Orcla 数据库复习2 --子查询和表连接的更多相关文章

  1. mysql update 子查询锁表问题

    mysql在Update带有子查询的时候,子查询的表会锁住,导致该表无法使用.比如 update A set comments = (select count(1) from B where id = ...

  2. ylb:SQL 表的高级查询-多表连接和子查询

    ylbtech-SQL Server: SQL Server-表的高级查询-多表连接和子查询 SQL Server 表的高级查询-多表连接和子查询. 1,ylb:表的高级查询-多表连接和子查询 返回顶 ...

  3. 肤浅的聊聊关联子查询,数据集连接,TiDB代码,关系代数,等等

    本章涉及的内容是TiDB的计算层代码,就是我们编译完 TiDB 后在bin目录下生成的 tidb-server 的可执行文件,它是用 go 实现的,里面对 TiPD 和 TiKV实现了Mock,可以单 ...

  4. MySQL 子查询(四)子查询的优化、将子查询重写为连接

    MySQL 5.7 ref ——13.2.10.10优化子查询 十.子查询的优化 开发正在进行中,因此从长远来看,没有什么优化建议是可靠的.以下列表提供了一些您可能想要使用的有趣技巧.See also ...

  5. MySQL 进阶6: 连接查询 (多表连接) : 等值连接/非等值连接 /左右全连接/内连接

    #进阶6: 连接查询 (多表连接) : 等值连接/非等值连接 /左右全连接/内连接 /* 含义: 当查询的字段来自于多个表时, 就会用到连接查询 一: sql 92标准 :等值连接 ,(#内连接) 1 ...

  6. MySQL数据库(11)----使用子查询实现多表查询

    子查询指的是用括号括起来,并嵌入另一条语句里的那条 SELECT 语句.下面有一个示例,它实现的是找出与考试类别('T')相对应的所有考试事件行的 ID,然后利用它们来查找那些考试的成绩: SELEC ...

  7. 数据库基础(子查询练习、链接查询(join on 、union)及其练习)

    子查询练习一:查询销售部里的年龄大于35岁的人的所有信息 练习二:将haha表中部门的所有数字代码转换为bumen表中的字符串显示 练习三:将haha表中部门的所有数字代码转换为bumen表中的字符串 ...

  8. MySQL数据库update更新子查询

    比如: ? 1 2 3 4 UPDATE test.tb_vobile a set a.name = '111 ' WHERE a.id = (select max(id) id from test. ...

  9. SQL Server高级内容之子查询和表链接

    1.子查询概念 (1)就是在查询的where子句中的判断依据是另一个查询的结果,如此就构成了一个外部的查询和一个内部的查询,这个内部的查询就是自查询. (2)自查询的分类 1)独立子查询 ->独 ...

随机推荐

  1. 分布式搜索引擎ElasticSearch+Kibana (Marvel插件安装详解)

    在安装插件的过程中,尤其是安装Marvel插件遇到了很多问题,要下载license.Marvel-agent,又要下载安装Kibana 版本需求 Java 7 or later Elasticsear ...

  2. UVA 11609 - Teams(二项式系数)

    题目链接 想了一会,应该是跟二项式系数有关系,无奈自己推的式子,构不成二项式的系数. 选1个人Cn1*1,选2个人Cn2*2....这样一搞,以为还要消项什么的... 搜了一下题解,先选队长Cn1,选 ...

  3. 【题解】【矩阵】【回溯】【Leetcode】Rotate Image

    You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwise). ...

  4. akka actor中的基本概念(学习小结)

    注:本文章是看blog后的一个阶段小结,只作为个人笔记, 原文链接:http://www.iteblog.com/archives/1154 官网地址贴上:http://doc.akka.io/doc ...

  5. 【报错】java.lang.ClassNotFoundException: org.apache.ibatis.session.SqlSession

    报错 java.lang.ClassNotFoundException: org.apache.ibatis.session.SqlSession 或者 java.lang.ClassNotFound ...

  6. 终于等到你,最强 IDE Visual Studio 2017 正式版发布

    Visual Studio 2017 正式版发布,该版本不仅添加了实时单元测试.实时架构依赖关系验证等新特性,还对许多实用功能进行了改进,如代码导航.IntelliSense.重构.代码修复和调试等等 ...

  7. 配置Eclipse编写HTML/JS/CSS/JSP页面的自动提示

    我们平时用eclipse开发jsp页面时智能提示效果不太理想,今天用了两个小时发现了eclipse也可以像Visual Studio 2008那样完全智能提示HTML/JS/CSS代码,使用eclip ...

  8. 别再为了this发愁了:JS中的this机制

    题记:JavaScript中有很多令人困惑的地方,或者叫做机制.但是,就是这些东西让JavaScript显得那么美好而与众不同.比方说函数也是对象.闭包.原型链继承等等,而这其中就包括颇让人费解的th ...

  9. TextureMerger1.6.6 一:Egret MovieClip的制作和使用

    本随笔记录TextureMerger来制作动画,并在Egret中使用. 参考官网教程:http://bbs.egret.com/forum.php?mod=viewthread&tid=918 ...

  10. 迷你MVVM框架 avalonjs 0.96发布

    本版本主要是性能优化与 fix BUG,改进如下: 处理notifySubscribers中的BUG,它在标准浏览器不会移除那些无用的视图刷新函数.详见这里 重构modelBindling.SELEC ...