oracle基础-子查询 备份

 一、什么是子查询

        子查询是在SQL语句内的另外一条select语句,也被称为内查询活着内select语句。在select、insert、update、delete命令中允许是一个表达式的地方都可以包含子查询,子查询也可以包含在另一个子查询中。

【例1.1】在Scott模式下,在emp表中查询部门名称(dname)为“RESEARCH”的员工信息。

select * from emp where deptno=(select deptno from dept where dname = 'RESEARCH')

对上面的代码进行分析,原本在emp表中不存在dname字段,但emp表中存在deptno字段。通过deptno字段可以管理两个表。

也可以使用多表关联查询来实现。

从上面两个查询语句可以看出,相比多表查询,子查询更加灵活、功能更加强大,而且容易理解。但是子查询的效率要高于多表关联查询。在一般情况下,外查询语句检索一行,子查询语句就需要检索一遍数据,然后判断外查询语句的条件是否满足。如果条件满足,则外查询语句将检索到的数据行添加到结果集中,如果条件不满足,则外查询语句继续检索下一行数据,所以子查询相对多表关联查询要慢一些。

注意:

1、子查询必须使用()括起来。

2、子查询中不能包括order by 子句。

3、子查询允许嵌套多层,但不能超过255层。

在Oracle 11g中,把子查询细化为单行子查询、多行子查询、关联子查询。

二、单行子查询

        单行子查询是指返回一行数据的子查询语句。当在where子句中引用单行子查询时,可以使用单行比较运算符(=,<,>,>=,<=,<>)。

        【例2.1】在emp表中,查询出既不是最高工资,也不是最低工资的员工信息。

        

select * from emp where sal > (select min(sal) from emp) and sal < (select max(sal) from emp)

         上面的语句中,如果内层子查询语句的执行结果为空值,那么外层的where子句就始终不会满足条件,这样改查询的结果就必然为空值,因为空值无法参与比较运算。

        在执行单行子查询时,要注意子查询的返回结果必须是一行数据,否则Oracle会提示无法执行。另外,子查询中也不能包含order by 子句,如果非要对数据进行排序,只能在外查询语句中使用order by 子句。

三、多行子查询

        多行子查询是指返回多行数据的子查询语句。当在where子句中使用多行子查询时,必须使用多行比较运算符(IN,ANY,ALL)。

        3.1 使用in运算符

        当在多行子查询中使用in运算符时,外查询会尝试与子查询结果中的任何一个结果进行匹配,只要有一个匹配成功,则外查询返回当前检索的记录。

        【例3.1.1】在emp表中,查询不是销售部门SALES的员工信息

        

select * from emp where deptno in (select deptno from dept where dname <> 'SALES')

        3.2 使用any运算符

        any运算符必须与单行操作符结合使用,并且返回行只要匹配子查询的任何一个结果即可。

        【例3.2.1】在emp表中,查询工资大于10号部门的任意一个员工工资的其他部门的员工信息

        

select * from emp where sal > any(select sal from emp where deptno = 10) and deptno <> 10

 

 3.3 使用all运算符

        all运算符必须与单行运算符结合使用,并且返回行必须匹配所有子查询的结果

        【例3.3.1】在emp表中,查询工资大于部门编号是30的所有员工信息

        

select * from emp where sal > all (select sal from emp where deptno = 30)

 

四、关联子查询

        在单行子查询和多行子查询中,内查询和外查询是分开执行的,也就是说,内查询的执行与外查询的执行没有关系,外查询仅仅是使用内查询的最终结果。在一些特殊需求的子查询中,内查询的执行需要借助外查询,而外查询的执行又离不开内查询的执行,这时,内查询和外查询是相互关联的,这种子查询就是称为关联子查询。

【例4.1】在emp表中,使用关联子查询检索公司大于相同职位的平均公司的员工信息

select * from emp e where sal > (select avg(f.sal) from emp f where e.job = f.job) order by job

注意:在执行关联子查询的过程中,必须遍历数据表中的每条记录,因此如果被遍历的数据表中有大量数据记录,则关联子查询的执行速度会比较缓慢。

        需要补充一点的是,关联子查询不但可以作为select语句的子查询,也可以作为insert,update,delete语句的关联子查询。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/542911.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

F. Chat Screenshots

思路&#xff1a;拓扑排序&#xff0c;如果存在满足所有截图的顺序&#xff0c;那么这个图中就会存在拓扑排序&#xff0c;这意味着图中不会存在循环。因此&#xff0c;我们的目标就是检查图的非循环性。 代码&#xff1a; int b[200010], vis[200010], edge[200010]; vector&…

【Java,Redis】Redis 数据库存取字符串数据以及类数据

1、 字符串存取数据 Resource private StringRedisTemplate stringRedisTemplate;//从Redis中获取string字符串 stringRedisTemplate.opsForValue().get("cache:shop:"id); //Json -> class Shop shop JSONUtil.toBean(ShopJson,Shop.class); //字符串写入redis…

【漏洞复现】大华智慧园区综合管理平台SQL注入漏洞

Nx01 产品简介 大华智慧园区综合管理平台是一款综合管理平台&#xff0c;具备园区运营、资源调配和智能服务等功能。该平台旨在协助优化园区资源分配&#xff0c;满足多元化的管理需求&#xff0c;同时通过提供智能服务&#xff0c;增强使用体验。 Nx02 漏洞描述 大华智慧园区…

【Unity】程序创建Mesh(二)MeshRenderer、光照、Probes探针、UV信息、法线信息

文章目录 接上文MeshRenderer&#xff08;网格渲染器&#xff09;Materials&#xff08;材质&#xff09;Material和Mesh对应Lighting光照Lightmapping材质中的光照 光源类型阴影全局光照Probes&#xff08;探针&#xff09;Ray Tracing&#xff08;光线追踪&#xff09;Additi…

Dynamo3.0.0已来,未来可期~

Hello大家好&#xff01;我是九哥~ 有阵子没用Dynamo&#xff0c;最近偶然打开官网&#xff0c;发现最新版本都已经升级到了3.0.0。 看了下升级记录&#xff0c;是从2.19版本直接跳到了3.0.0&#xff0c;简单用了下&#xff0c;变化还是挺大的&#xff0c;未来可期啊~ …

非空约束

oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645 非空约束 所谓的非空约束&#xff0c;指的是表中的某一个字段的内容不允许为空。如果要使用非空约束&#xff0c;只需要在每个列的后面利用“NOT NULL”声明即可 -- 删除数…

使用Laravel开发项目

如何使用Laravel框架开发项目 一、安装Laravel框架 1.在安装Laravel框架钱我们需要先查看要安装的Laravel框架版本以及版本所需要的安装运行条件。 2.配置好安装环境后再安装Laravel框架 2.1.配置安装环境 1&#xff09;PHP版本 2&#xff09;PHP OpenSSL扩展 3&#xff…

docker容器技术基础入门-1

文章目录 容器(Container)传统虚拟化与容器的区别Linux容器技术Linux NamespacesCGroupsLXCdocker基本概念docker工作方式docker容器编排 容器(Container) 容器是一种基础工具&#xff1b;泛指任何可以用于容纳其他物品的工具&#xff0c;可以部分或完全封闭&#xff0c;被用于…

一周学会Django5 Python Web开发-Jinja3模版引擎-安装与配置

锋哥原创的Python Web开发 Django5视频教程&#xff1a; 2024版 Django5 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili2024版 Django5 Python web开发 视频教程(无废话版) 玩命更新中~共计35条视频&#xff0c;包括&#xff1a;2024版 Django5 Python we…

双路控制比例方向阀放大器

该模块比例放大器用于控制一个带有两个螺线管的比例方向控制阀或一个/两个独立的比例压力阀或比例节流阀&#xff0c;每个阀带有一个或二个螺线管。 各种可调参数允许对相应阀门的最佳适应。单路双路四路控制&#xff0c;供电24VDC&#xff0c;输入指令兼容多种可选&#xff0c…

Redis 的常用基本全局命令【小林优选】

前言 Redis 常用的有 5 种数据结构&#xff0c;字符串&#xff0c;列表&#xff0c;哈希表&#xff0c;集合&#xff0c;有序集合&#xff0c;每一种数据结构都有自己独特的命令&#xff0c;但也有些通用的全局命令&#xff0c;本文所提到的是最基本的命令&#xff0c;Redis 的…

【Qt】QT串口接收一帧数据有时候不完整,需要接收两次

1. 现象 //正常数据 Read: "12345678901234567890123456789012345678901234567890" //异常数据 Read: "12345678901234567890123456789012" Read: "345678901234567890"2. 问题代码 #include "serialbase.h"QString seria…