oracle子查询
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了oracle子查询,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2653字,纯文字阅读大概需要4分钟。
内容图文
![oracle子查询](/upload/InfoBanner/zyjiaocheng/531/67e51733282a42cabbfbde96301df2de.jpg)
子查询就是嵌套在查询语句内的查询,后续查询可以使用先前查询的结果,用以代替暂存表或变量存储先前查询结果。 子查询的外层为较高的层级,以下称之为“主查询”。派生表是子查询的一个特殊情况,他是应用于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;
内容总结
以上是互联网集市为您收集整理的oracle子查询全部内容,希望文章能够帮你解决oracle子查询所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。