Home >Database >Mysql Tutorial >oracle 子查询

oracle 子查询

WBOY
WBOYOriginal
2016-06-07 15:27:151388browse

子查询就是嵌套在查询语句内的查询,后续查询可以使用先前查询的结果,用以代替暂存表或变量存储先前查询结果。 子查询的外层为较高的层级,以下称之为“主查询”。派生表是子查询的一个特殊情况,他是应用于FROM子句中的 SELECT完整命令,以数据表别名引用

子查询就是嵌套在查询语句内的查询,后续查询可以使用先前查询的结果,用以代替暂存表或变量存储先前查询结果。

子查询的外层为较高的层级,以下称之为“主查询”。派生表是子查询的一个特殊情况,他是应用于FROM子句中的

SELECT完整命令,以数据表别名引用此子查询时,同使用一般数据表一样。

 

子查询以内外层是否进行连接(JOIN)可分成嵌套子查询相关子查询两种类型

 

一、嵌套子查询

1、单行子查询

单行子查询将传回单一字段(Column)的一行(Row)数据值,可应用于任何需要纯量值的场合,从而简化查询中需要使用

变量的那些需求。以下范例将查询学校为广州大学所在的单位的所有人员,其中子查询用来查询学校为广州大学的部门ID

主查询则利用子查询所传回的部门编号查询人员数据表

select name,account,unit_id
from sys_user
where unit_id = 
(
select id from sys_unit 
where name = '广州大学'
)


2、多行子查询

多行子查询将传回单一字段(Column)的多行(Rows)数据值,当子查询传回多笔数据值时,必须改用IN。将上述范例增加查询

另一个学校名称为广东工业大学的部门编号

select name,account,unit_id
from sys_user
where unit_id in 
(
select id from sys_unit 
where name in('广州大学','广东工业大学')
)


 

二、相关子查询

下面介绍将EXISTS应用于相关子查询的方法。EXISTS是用来检查某个数据是否符合子查询的条件,相反为NOT  EXISTS.。

当在子查询中找到符合条件的数据时,EXISTS将传回TRUE,而这笔数据则被外层查询传回。

select name
from sys_user u
where exists
(
select 1 --可为任何常数,如数值1
from sys_unit unit
where u.unit_id = unit.id and name in('广州大学','广东工业大学')
)


嵌套子查询与相关子查询的差别在于:子查询是否可以单独单独执行,相关子查询必须与外层查询相互关联,外层查询必须将每一笔

数据传入子查询进行比对,符合子查询的数据最后才会被外层查询传回。

 

1、派生表

派生表是应用于FORM子句中的子查询,将子查询中的数据暂时视为一个虚拟数据表以供主查询使用。子查询时一完整查询,

可使用数据表连接、GROUP BY甚至是ORDER  BY子句,将子查询置于主查询的FORM子句后,需将子查询置于括号内并予以命名,像使用一般数据表那样。

select u.name
from sys_user u,
(
select id,name
from sys_unit where name in('广州大学','广东工业大学')
) t
where u.unit_id = t.id 


2、通用表表达式

对于较复杂的查询命令,有时将需要重复运用相同的子查询,采用派生表的作法将耗用数据库许多资源,造成执行效率低下等问题。为避免重复执行相同的子查询,建议采用通用表表达式,即WITH命令。

with Emp
as
(
select id,name
from sys_unit where name in('广州大学','广东工业大学')
)
--后续操作与一般表的使用方式向他
select u.name
from sys_user u,Emp e
where u.unit_id = e.id;


 

 

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn