Oracle---SQL子查询---详解
子查询其实就是指嵌入到其他语句中的select语句,也称其为嵌套查询。
值得注意的在DDL语句中应用子查询的时候子查询可以使用order by 子句。
但是在DML语句中的where子句,set子句中,子查询是不能使用order by子句的。 简单例子:查询工作和SMITH一样的所有员工的信息(不包含SMITH)
select ename ,sal from emp e where job =
(select job from emp where ename = 'SMITH')
and e.ename <> 'SMITH'; 子查询分类
单行子查询
只返回一条记录的子查询 ,就可上述例子一样
--返回工资比SMITH多的员工和工资情况
select ename ,sal from emp where sal> ( select sal from emp where ename ='SMITH' ) ; 能够用于当行子查询的操作符有>、<、=、like等等 多行子查询
多行子查询返回的是一个记录组,也就是多条记录,这种情况对于子查询的操作就
应该是in、any、all,exits 等。直接一个实例来看
--查询各部门中员工工资最高的员工信息
select ename ,deptno,sal,job from emp e where not exists ( select ename,deptno,job from emp where deptno = e.deptno and sal > e.sal )
order by deptno
; 多行子查询的一些操作符的使用示例:
--in操作符的使用
--查询员工的职业类型在部门10中有的员工的信息
select ename,job,sal,deptno from emp where job in ( select distinct job from emp where deptno =10 )
;
ALL操作符:
--ALL操作符的使用
--查询员工的工资大于30号部门的所有员工的信息
select ename,sal,deptno from emp where sal > all ( select sal from emp where deptno=30 )
;
--">all"表示大于最大的,"
ANY操作符:
--ANY操作符的使用
--只要员工的工资存在这种情况:
--即他的工资情况比30部门的其中一个人的工资多就查询出来 select ename,sal,deptno from emp where sal>any ( select sal from emp where deptno = 30 )
; “>ANY”意味着大于最小值," 多列子查询
指的是子查询语句返回的是多列。
例如查询:某个名叫SMITH的员工,但是由于员工的名字可能出现重复,因此需要结合其工作和部门id进行判断。
--多列子查询实例
select ename ,job ,deptno from emp
where (ename,job,deptno) = (
select ename, job,deptno from emp where ename='SMITH' )
;--这里主要在于说明多列子查询的使用,并不注重其实际意义
● 成对比较
--成对比较
select ename ,sal,comm ,deptno from emp
where (sal,nvl(comm,-1)) in (
select sal,nvl(comm,-1) from emp
where deptno = 30 );
● 非成对比较
--非成对比较
elect ename ,sal,deptno,comm from emp
where sal in (
select sal from emp
where deptno = 30
)
and nvl(comm,-1) in (
select nvl(comm,-1) from emp
where deptno = 30 ); 其他子查询
1、相关子查询
是指需要引用主查询表列的子查询 语句。相关子查询是通过exists 来实现的 。
--查询在NEW YORK工作的员工的信息
select ename ,job ,sal ,deptno from emp
where exists
(
select 1 from dept
where dept.deptno = emp.deptno and dept.loc ='NEW YORK'
);
--相关子查询的执行过程: 相关子查询会引用外部查询的一列或多列,在执行的时候外部查询的每一行被一次一行的 传递给子查询,子查询依次读取外部查询传递过来的每一个值,并将其用到子查询上,直到外部 查询的所有行都用完为止,然后返回查询结果。 2、FROM子句中的子查询
在from子句中使用子查询的时候子查询会被当做一个view对待,需要给子查询指定别名。
--查看比本部门平均工资高的员工信息
select ename,job,sal from emp , (
select deptno,avg(sal) as avgsal from emp
group by deptno
) tmp_dept
where emp.deptno=tmp_dept.deptno and sal >tmp_dept.avgsal;
3、DML语句中使用子查询
--DML语句中使用子查询
--insert中
insert into employee (id,name,title,salary)
select emptno,ename ,job,sal from emp;
--update中
update emp set (sal,comm)= (
select sal,comm from emp
where ename =SMITH ) where job = ( select job from emp where ename =SMITH ) ; --去除销售部门 delete from emp where deptno = ( select deptno from dept where dname =SALES ) ; --DML语句中使用子
where ename ='SMITH'
)
where job =
(
select job from emp where ename ='SMITH' )
;
--去除销售部门
delete from emp where deptno = (
select deptno from dept
where dname ='SALES'
);
4、在DDL语句中使用子查询
通过select子查询来实现创建视图的方式来说明其使用方法
需要注意的是在执行下面的sql语句之前,要对scott用户赋予创建视图的权利
SQL>conn / as sysdba
SQL>grant create view to scott;
--创建视图并查询视图
create or replace view dept10 as
select empno,ename ,job,sal,deptno from emp
where deptno = 10 order by empno;
select * from dept10;
Oracle---SQL子查询---详解的更多相关文章
- Mysql高手系列 - 第12篇:子查询详解
这是Mysql系列第12篇. 环境:mysql5.7.25,cmd命令中进行演示. 本章节非常重要. 子查询 出现在select语句中的select语句,称为子查询或内查询. 外部的select查询语 ...
- oracle 子查询详解 in和exists的区别
sql允许多层嵌套,子查询是嵌套在其他查询中的查询.我们可以把子查询当做一张表来看到,即外层语句可以把内嵌的查询结果当做一张表使用. 子查询查询结果有三种情况 不返回查询记录.若子查询不返回记录则主查 ...
- Oracle SQL优化规则详解
1. 选用适合的Oracle优化器 Oracle的优化器共有3种: a. RULE (基于规则) b. COST (基于成本) c. CHOOSE (选择性) 设置缺省的优化器,可以通过对init.o ...
- SQL常规查询详解
一.交叉连接(cross join) 交叉连接(cross join):有两种,显式的和隐式的,不带on子句,返回的是两表的乘积,也叫笛卡尔积. 例如:下面的语句1和语句2的结果是相同的. 语句1:隐 ...
- 为什么说JAVA中要慎重使用继承 C# 语言历史版本特性(C# 1.0到C# 8.0汇总) SQL Server事务 事务日志 SQL Server 锁详解 软件架构之 23种设计模式 Oracle与Sqlserver:Order by NULL值介绍 asp.net MVC漏油配置总结
为什么说JAVA中要慎重使用继承 这篇文章的主题并非鼓励不使用继承,而是仅从使用继承带来的问题出发,讨论继承机制不太好的地方,从而在使用时慎重选择,避开可能遇到的坑. JAVA中使用到继承就会有两 ...
- Oracle的exp/imp详解
原文地址:Oracle的exp/imp详解 作者:jxlazzw 备份概述 逻辑备份:备份可分为两类 ,物理备份和逻辑备份 物理备份:该方法实现数据库的完整恢复,但需要极大的外部存储设备,例如磁带库, ...
- oracle中imp命令详解 .
转自http://www.cnblogs.com/songdavid/articles/2435439.html oracle中imp命令详解 Oracle的导入实用程序(Import utility ...
- oracle expdp/impdp 用法详解
http://hi.baidu.com/hzfsai/item/4a4b3fc4b1cf7e51ad00efbd oracle expdp/impdp 用法详解 Data Pump 反映了整个导出/导 ...
- sql各种连接详解
迁移时间:2017年6月1日16:33:58 CreateTime--2016年9月14日11:19:00Author:Marydon sql各种连接详解 参考链接: http://www.jb5 ...
随机推荐
- 我的Android进阶之旅------>如何将Activity变为半透明的对话框?
我的Android进阶之旅------>如何将Activity变为半透明的对话框?可以从两个方面来考虑:对话框和半透明. 在定义Activity时指定Theme.Dialog主题就可以将Acti ...
- 我的Android进阶之旅------>Android颜色值(RGB)所支持的四种常见形式
Android中颜色值是通过红(Red).绿(Green).蓝(Blue)三原色,以及一个透明度(Alpha)值来表示的,颜色值总是以井号(#)开头,接下来就是Alpha-Red-Green-Blue ...
- SQL2000 3核6核 CUP 安装SP4
1.找到HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432node\Microsoft\MSSQLServer \MSSQLServer\Parameters\ 2.然后加入下面的 ...
- activiti基础--1------------------------生成.bpmn和.png以及部署流程定义
helloworld.dbmn <?xml version="1.0" encoding="UTF-8"?> <definitions xml ...
- linux清空屏幕
linux清空屏幕 clear ctrl+L reset也是真正的清空终端屏幕,这个命令执行起来有点慢,但它的兼容性显然比之前的那个好,在终端控制错乱时非常有用
- LeetCode:区域和检索【303】
LeetCode:区域和检索[303] 题目描述 给定一个整数数组 nums,求出数组从索引 i 到 j (i ≤ j) 范围内元素的总和,包含 i, j 两点. 示例: 给定 nums = [ ...
- ICP 求解相机思路
1.之前仍然是需要创建find_feature_matches,和pixel2cam,一个是用来匹配描述子的,一个是把像素坐标转成归一化平面坐标的.里面的变量都要带上&.2.因为是3d-3d. ...
- ThinkPHP 小技巧
中文截取函数 函数解释: msubstr($str, $start=0, $length, $charset=”utf-8″, $suffix=true) $str:要截取的字符串 $start=0: ...
- 算法(Algorithms)第4版 练习 1.5.10
Yes, but it could increase the tree height, so the performance guarantee would be invalid.
- Kafka- Kafka架构功能
Kafka是一个高吞吐量的分布式消息系统,一个分布式的发布-订阅消息系统.Kafka是一种快速,可拓展的,设计内在就是分布式的,分区的可复制的提交日志服务. Apache Kafka与传统消息系统相比 ...