Oracle 数据库基础学习 (六) 子查询
子查询在一个select中出现多个嵌套查询语句
1、在where子句中使用子查询(一般返回"单行单列" "单行多列" "多行单列"(可以提供in、any、all ))
示例1:查找低于平均工资的雇员信息(返回单行单列)
select * from emp where sal < (select avg(sal) from emp)
示例2:查找出公司最早雇佣的雇员信息(返回单行单列)
select * from emp where hiredate =(select min(hiredate) from emp)
示例3:与scott从事同一个工作,且工资相同(返回多行单列)--但是一般不这么使用
select * from emp
where ((job, sal)= (select job, sal from emp where ename='SCOTT')) and (ename != 'SCOTT')
在子查询返回多行单列的时候,可以使用in、any、all 进行比较
⑴ in和not in(不能与null一起使用)的用法
示例:查询和职位是MANAGER工资不同的员工信息
select * from emp
where sal not in (select sal from emp where job='MANAGER') ;
⑵ any的用法( “>any”大于最小的 “<any”小于最大的)
示例1:查询和职位是MANAGER工资相同的员工信息(”=any”和in一样用法)
select * from emp
where sal =any (select sal from emp where job='MANAGER') ;
示例2:查询比职位是MANAGER工资最低工资还高的员工信息(”>any”就是比最小的大)
select * from emp
where sal >any (select sal from emp where job='MANAGER') ;
示例3:查询比职位是MANAGER工资最高工资还低的员工信息(”<any”就是比最大的小)
select * from emp
where sal <any (select sal from emp where job='MANAGER') ;
⑶ all的用法(“>all”比最大的大 “<all”比最小的小)
示例1:查询比职位是MANAGER工资都高的员工信息(”>all”就是比最大的还大)
select * from emp
where sal >all (select sal from emp where job='MANAGER') ;
示例2:查询比职位是MANAGER工资都低的员工信息(”<all”就是比最小的还小)
select * from emp
where sal <all (select sal from emp where job='MANAGER') ;
2、在having子句中使用子查询,使用的情况只有在子查询返回单行单列,并且使用统计函数的情况
示例1:查询出高于公司平均工资的员工的职位名称,职位人数,平均工资
select job, count(empno), avg(sal)
from emp
group by job
having avg(sal) > (select avg(sal) from emp) ;
3、在select子句中使用子查询(返回单行单列,不过一般不使用)
示例1:查询每个雇员的编号、姓名、职位、部门名称
使用多表查询:
select e.empno, e.ename, e.job, d.dname
from emp e, dept d
where e.deptno=d.deptno(+) ;
使用select子查询:
select e.empno, e.ename, e.job, (select dname from dept d where e.deptno=d.deptno) dname
from emp e ;
4、在from子句中使用子查询(返回多行多列)
示例1:查询每个部门名称、位置、部门人数
使用多表查询:
select d.dname, d.loc, count(empno)
from emp e, dept d
where e.deptno=d.deptno(+)
group by d.dname, d.loc ;
使用from子查询:
|-查询部门的名称、位置、编号
select deptno, dname, loc from dept ;
|-查询部门的编号和部门人
select deptno, count(empno)
from emp
group by deptno ;
|-实现在from的子查询,相当与将两张表做多表连接查询
select d.dname, d.loc, temp.count
from dept d, (select deptno, count(empno) count from emp group by deptno ) temp
where d.deptno=temp.deptno(+) ;
注意:1、当子查询返回单行单列、多行单列、单行多列的情况,在where子句中实现子查询
2、having子句中使用子查询,使用的情况只有在子查询返回单行单列,并且使用统计函数的情况
3、当子查询返回多行多列的情况,在from子句中实现子查询
4、一般不在select子句中实现子查询
Oracle 数据库基础学习 (六) 子查询的更多相关文章
- 数据库Mysql的学习(六)-子查询和多表操作
)*0.05 WHERE card_id ='20121xxxxxx'; //子查询就是一个嵌套先计算子查询 SELECT * FROM borrow WHERE book_id =(SELECT b ...
- Oracle 数据库 基础学习 (一) SQL基本知识
Oracle 从零开始,不知所措.要掌握一种技能,最好的方式是先学会怎么使用它,然后再深入学习,先有样子,再有技术. 一,什么是数据库? 为什么需要数据库? 数据库实质上是一个信息的列表,或者是一 ...
- Oracle 数据库基础学习 (七) SQL语句综合练习
一.多表查询综合练习 1. 列出高于在30部门工作的所有人员的薪金的员工的姓名.部门名称.部门编号.部门人数 分析: 需要的员工信息: |-emp表:姓名.部门编号 |-dept表:部门名称.部门编 ...
- Oracle 数据库基础学习 (五) 多表查询
多表查询:查询结果需要用到两个或者以上表,此时需要多表连接,产生多表查询 1.内连接(等值连接) 示例:将两个表内容连接显示 select * from dept d, emp e where d.d ...
- Oracle 数据库基础学习 (三) Oracle 四个表结构
Oracle 四个表的 emp dept salgrade bunus 的结构,记住有利于后期SQL语句的学习 雇员表(emp) No. 字段 类型 描述 1 empno NUMBER(4) 表示 ...
- Oracle 数据库基础学习 (四) group by的使用
group by分组查询 示例:要求查询出每个部门的编号,人数,以及最高和最低工资 select deptno, count(empno), max(sal), min(sal) from em ...
- Oracle 数据库基础学习 (二) 学习小例子:创建一个表,记录商品买卖的情况
运行环境:Oracle database 11g + PL/SQL Developer ex: --创建一个表 create table plspl_test_product( --加入not n ...
- Oracle 数据库基础学习 (八) PL/SQL综合练习
1.定义游标:列出每个员工的姓名.部门名称并编程显示第10个到第20个记录. declare cursor zemp_cursor is (select temp.ename, temp.dname ...
- Mysql数据库基础学习笔记
Mysql数据库基础学习笔记 1.mysql查看当前登录的账户名以及数据库 一.单表查询 1.创建数据库yuzly,创建表fruits 创建表 ) ) ,) NOT NULL,PRIMARY KEY( ...
随机推荐
- Android开发学习之路-回调实现Service向activity传递数据
开启服务的时候,如果我们是通过bindService来绑定服务并且要向服务传递数据,可以直接在Intent中设置bundle来达到效果,但是如果是我们需要从服务中返回一些数据到Activity中的时候 ...
- atitit。企业的价值观 员工第一 vs 客户第一.docx
atitit.企业的价值观 员工第一 vs 客户第一.docx 1. 客户第一的说法是错误的,员工优先是正确的,理念与价值观1 1.1. 任何一个组织,应该组织成员优先级要比外部成员高才对1 1.2. ...
- iOS---------- @synchronized(self)的用法
1. synchronized 这个主要是考虑多线程的程序,这个指令可以将{ } 内的代码限制在一个线程执行,如果某个线程没有执行完,其他的线程如果需要执行就得等着. Objective-C除了提 ...
- iOS开发——高级技术精选OC篇&Runtime之字典转模型实战
Runtime之字典转模型实战 如果您还不知道什么是runtime,那么请先看看这几篇文章: http://www.cnblogs.com/iCocos/p/4734687.html http://w ...
- Linux常用命令01
Linux对于我们来说,就是跑程序的运行平台,简单的来说,就是服务器,自己也没怎么系统的学习Linux的命令,随着项目的需要, 比如要查找日志,哪里出问题了,哪里报错了,因此自己也慢慢地懂一些常用的L ...
- 关于Thread.currentThread()和this的差异
重新来看多线程时,被这结果搞懵逼了.不多说,直接上代码: public class MyThread02 extends Thread { public MyThread02() { System.o ...
- 因为相同类型的其他实体已具有相同的主键值。在使用 "Attach" 方法或者将实体的状态设置为 "Unchanged" 或 "Modified" 。。。
因为相同类型的其他实体已具有相同的主键值.在使用 "Attach" 方法或者将实体的状态设置为 "Unchanged" 或 "Modified&quo ...
- 使用SQL Server Audit记录数据库变更
最近工作中有一个需求,就是某一个比较重要的业务表经常被莫名其妙的变更.在SQL Server中这类工作如果不事前捕获记录的话,无法做到.对于捕获变更来说,可以考虑的选择包括Trace,CDC. ...
- C# XmlReader
一个非常全面的XML解析类 using System; using UnityEngine; using System.Xml; using System.Collections; using Uni ...
- Unity 碰撞检测中碰撞器与触发器的区别
要产生碰撞必须为游戏对象添加刚体(Rigidbody)和碰撞器,刚体可以让物体在物理影响下运动.碰撞体是物理组件的一类,它要与刚体一起添加到游戏对象上才能触发碰撞.如果两个刚体相互撞在一起,除非两个对 ...