Oracle 多行、多列子查询
本文使用到的是oracle数据库scott方案所带的表,scott是oracle数据库自带的方案,使用前请确保其解锁
一、多行子查询
多行子查询子查询是嵌入在其他Sql语句中的select语句,Oracle子查询分为两种:一种是单行子查询,一种是多行子查询
1、单行子查询
单行子查询的select语句只返回一行数据,也就是说嵌入在其他Sql语句中的那个select查询值返回一行数据。
例:查询emp表中,与Smith同一部门的所有员工
select * from emp where deptno=
(select deptno from emp where ENAME='SMITH');--这里的select查询只返回一行数据
所以,我们把子查询的嵌入的select语句至返回一行数据的这类子查询,称为单行子查询
2、多行子查询
了解了单行子查询的原理,那么多行子查询自然而然的就知道了,多行子查询就是嵌入在其他Sql语句中的select查询返回多行数据
例:查询所有员工中工作和部门10的工作一样的员工信息
select * from emp where job in
(select distinct job from emp where deptno=10) --这里的select查询返回多行记录
注意左图红框中的关键字只能用in,不能使用'=','='号表示一对一,in表示处于一个范围(用来处理子查询返回多行记录),如果这里使用'='号,也就是执行如下语句:
select * from emp where job =
(select distinct job from emp where deptno=10) --这里的select查询返回多行记录
3、多行子查询中的特殊操作符
虽然in能解决多行子查询中的=的问题,但是如果要和子查询的结果集中的字段比较大小呢?显然用in是不够用的!!!ok,下面即将使用的操作符,就是来解决这个问题的.
3.1、多行子查询中的all操作符
例:查询比部门30所有员工的工资都要高度员工信息
select * from emp where sal>
(select sal from emp where deptno=30) --这里的select查询返回多行记录
执行sql之后发现和=是一样的问题,因为'>'表示一对一的关系,而子查询返回多个结果集,所以报错了,那怎么办呢?总不可能用in吧!这里就要使用all了,如下代码:
select * from emp where sal>
all (select sal from emp where deptno=30) --这里的select查询返回多行记录
在子查询前面加上all关键字,表示当检索emp表时,只检索出哪些比(子查询结果集中最大的还要大)的数据行
所以上面的代码也可以这样表示:
select * from emp where sal>
(select max(sal) from emp where deptno=30)
3.2、多行子查询中的any操作符
在了解了all操作符之后,any操作符也就好理解了。
select * from emp where sal>
any (select sal from emp where deptno=30) --这里的select查询返回多行记录
这段代码表示:检索出emp表,只检索那些(只要比子查询的结果集的任意一行大)就行的数据行,所以上面的代码也相当于:
select * from emp where sal>
(select min(sal) from emp where deptno=30) --这里的select查询返回多行记录
二、多列子查询
例1:查询与smith部门和岗位完全相同的员工
1、首先使用多行子查询来解决这个问题
select * from emp where deptno=
(select deptno from emp where ename='SMITH')
and job=
(select job from emp where ename='SMITH')
2、使用多列子查询来解决这个问题
select * from emp where (deptno,job)=(select deptno,job from emp where ename='SMITH') --列的顺序一定要相同
加入换了列的顺序,代码如下:
select * from emp where (job,deptno)=(select deptno,job from emp where ename='SMITH') --列的顺序一定要相同
例2:查询高于自己部门平均工资的员工信息
select * from emp a,(select deptno,ceil(avg(sal)) as avgsal from emp group by deptno) b
where a.deptno=b.deptno and a.sal>b.avgsal
解决思路:通过分组函数求出各个部门的平均薪水,然后将平均薪水通过deptno和emp进行连表查询,然后比较薪水和平均值,得出结果集。
Oracle 多行、多列子查询的更多相关文章
- oracle 多行转多列查询
oracle 多行转多列查询 ---create table Fruit(id int,name varchar(20), Q1 int, Q2 int, Q3 int, Q4 int);inse ...
- Oracle学习总结_day03_day04_条件查询_排序_函数_子查询
本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! day03_条件查询_排序_函数 清空回收站: PUR ...
- Oracle多表的简单查询
Oracle多表的简单查询 .多表查询 多表查询是指基于两个和两个以上的表或是视图的查询. 问题:显示雇员名,雇员工资及所在部门的名字[笛卡尔集]? select t.ename,t.sal,t1.d ...
- oracle入门之对表数据查询(三)
oracle表复杂查询--子查询 什么是子查询? 子查询是指嵌入在其它sql语句中的select语句,也叫嵌套查询. 单行子查询 单行子查询是指只返回一行数据的子查询语句. 请思考:如果显示与smit ...
- .Net程序员学用Oracle系列(14):子查询、集合查询
1.子查询 1.1.子查询简介 1.2.WITH 子查询 2.集合查询 2.1.UNION 和 UNION ALL 2.2.MINUS 2.3.INTERSECT 2.4.集合运算与 ORDER BY ...
- Oracle SQL:select各类查询语句总结
SQL查询语句总结 数据查询语言:即DML(Data Mannipulation Language)数据操纵语言,用于查询.操纵数据表资料行 本手册所有示例引用表均以TIPTOP GP ERP数据库 ...
- Oracle 数据库基础:数据查询与操作
SELECT uname FROM TUser WHERE uname=‘admin’ SELECT 字段名列表 FROM 表名 WHERE 条件; 在Oracle数据库中,对象是属于模式的,每个账户 ...
- Oracle与Mysql的高级查询与难点sql
一.连接查询 1.内连接 内连接用于返回满足连接条件的所有记录.默认情况下,在执行连接查询时如果没有指定任何连接操作符,那么这些连接查询都属于内连接. Sql代码 1. SELEC ...
- Oracle Flashback Technologies - 闪回查询
Oracle Flashback Technologies - 闪回查询 查看表中,某行数据的修改记录 #创建一个表,并插入和修改数据 SQL> create table y3(id )); T ...
随机推荐
- 编写高质量代码改善C#程序的157个建议——建议149:使用表驱动法避免过长的if和switch分支
建议149:使用表驱动法避免过长的if和switch分支 随着代码变得复杂,我们很容易被过长的if和switch分支困扰. 一个类枚举类型Week如下: enum Week { Monday, Tue ...
- mysql - 查看表字段和字段描述
1.mysql查看表字段和字段描述 SELECT column_name, column_comment FROM information_schema.columns WHERE table_sch ...
- Activity Fragment转场动画
Activity转场动画 先介绍个动画的好例子:https://github.com/lgvalle/Material-Animations Activity的转场动画是通过overridePendi ...
- 学习python3
定义一个函数 你可以定义一个由自己想要功能的函数,以下是简单的规则: 函数代码块以 def 关键词开头,后接函数标识符名称和圆括号 (). 任何传入参数和自变量必须放在圆括号中间,圆括号之间可以用于定 ...
- mysql中四种存储引擎的区别和选择
前言 数据库存储引擎是数据库底层软件组织,数据库管理系统(DBMS)使用数据引擎进行创建.查询.更新和删除数据.不同的存储引擎提供不同的存储机制.索引技巧.锁定水平等功能,使用不同的存储引擎,还可以 ...
- CodeForces 227E Anniversary (斐波那契的高妙性质+矩阵快速幂)
There are less than 60 years left till the 900-th birthday anniversary of a famous Italian mathemati ...
- DRBD 数据镜像软件
1>DRBD介绍 1>数据镜像软件DRBD介绍 分布式块设备复制(Distributed Relicated Block Deivce,DRBD),是一种基于软件.基于网络的块复制存储解 ...
- 关于C#里面SQLite读取数据的操作
做C#朋友的一个获取DataSet函数,对C#不熟,整理整理,了解怎么用 //挂载表格时候用 public static DataSet Query(string SQLString) { using ...
- Oracle 表关联性 Update 语句的改写,推荐改写方法1
同事写了一个逻辑稍复杂的Update 语句,觉得在代码可读性上有些转圈,交给我帮忙改下. 以下根据原SQL,使用两种方法进行改写,个人推荐方法1的改写.方法2拆分两个SQL来写,代码可读性最强,但是S ...
- 相当郁闷的问题,TabHost选项卡标签图标始终不出现?
在学习Android TabHost布局过程中,很多教程告诉我,这样来显示选项卡标签的图标和文字: TapSpec spec1 = tabHost.newTabSpec("tab 1&quo ...