首页
学习
活动
专区
圈层
工具
发布

Oracle查询优化-03操作多个表

从多个表中返回丢失的数据 问题 解决方案 full join union all 13 多表查询时的空值处理 问题 解决方案 3.1 记录集的叠加 问题 要将来自多个表的数据组织到一起,就像将一个结果集叠加到另外一个上面一样...这些表不必有相同的关键字,但是他们对应列的数据类型必须相同。 解决方案 使用union all 把多个表中的行组合到一起。...解决方案 ORACLE VERSION : Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 IN SQL> explain plan...JOIN 因为子查询的join列(emp2.ename ,emp2.job ,emp2.sal)没有重复行,说这个查询可以直接改写为inner join SQL> explain plan for...> ---- 3.10 聚集与内连接 问题 解决方案 结论 ---- 3.11 聚集与外连接 问题 解决方案 结论 ---- 3.12 从多个表中返回丢失的数据 问题 同时返回多个表中丢失的数据。

3.7K20

Oracle函数学习(单表查询和子查询)

–单表查询: –当需要的数据在一张表中,考虑使用单表查询 –多表联合查询: –当需要查询的数据分布在多张表中,考虑使用多表联合 –子查询学习: –使用时机:当查询的筛选条件不明确时,考虑使用子查询...内容 from 表名 where 字段名 比较运算符 子查询语句 –查询所有比雇员“CLARK”工资高的员工信息 select * from emp where sal>(select sal from...: --使用:子查询的结果只有一个字段但是字段有n个值,考虑使用多行子查询,其实就是使用关键字 --关键字1:any 任意 --select 内容 from 表名 where 字段名...比较运算符 any 子查询语句 --关键字2:all 所有 --select 内容 from 表名 where 字段名 比较运算符 all 子查询语句 --关键字3:in...表示任意存在,相当于 = any --select 内容 from 表名 where 字段名 in 子查询语句 --select 内容 from 表名 where

1.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQL之美 - Oracle 子查询优化系列精讲

    那么redu_owner_id返回的结果集将直接影响整个SQL性能的好坏。 下面继续查看SQL部分,可以发现一个重要的信息就是在子查询中存在rownum子查询最多返回10行。...在OLTP系统中,存在一个表最后最多返回10行的情况,这里也就大概想到了用子查询做去驱动表了,如果执行计划中,没有用子查询做驱动表,那么很有肯能执行计划就是错误的,那么这里的自己认为的驱动表与之前根据SQL...在执行计划中,这里特意把子查询标记出来,就是需要引起重视,子查询当着一个整体与主查询做HASH链接,没有作为驱动表走NL,也就可以肯定整个执行计划连最基本的驱动表都选择错误。下图可以更直观的看到。...在上面提到了子查询中最多返回10行,可以用于做NL的驱动,要让子查询的表做驱动表,应该怎么来修改SQL?...下面我们拿返回8611行的绑定变量来做测试 添加提示后的SQL如下: ? 红色部分就是添加的提示 执行计划 ? 可以看到,子查询的结果集已经作为驱动表了。 统计信息 ?

    2.5K40

    sql的子连接查询

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。...本文链接:https://blog.csdn.net/luo4105/article/details/51397825 一直没有注重于sql这一块,现在的项目有大量的统计,报表,以前都是多表连接或者用...mybatis的延迟加载之类的,这几天心血来潮自己查了一下,发现了sql子查询这个好东西,感觉方便多了,速度也快多了(自我感觉)。...sql的子查询是可以在把数据查出来后在查出一条其他表的关联数据的一项(多项或者多条都会报错), 比如我们要查询用户表(user)并加上一个列(rolename)表示它代表的权限的名字,那么我们可以这么写...roleId=user.roleId) as rolename,'2016-05-13' as nowTime from user 这sql这几天真的写的蛮开心,哈哈

    5.2K20

    Oracle实现like多个值的查询

    客户给定的被叫号码如图所示: 查询出来的结果如下图所示(本批次的结果不是上图导入的结果查询的,为了格式说明,因此导入两张结果不相关的图片): 由于客户给的被叫号码很不规范,查询的时候比较麻烦。...分析过程: 我新建了一个表security_phonebill_callee_num,用以存放导入的被叫号码信息 所有的通话数据保存在t_phonebill_201702中,想要查询必须要实现like,...,有时候有一百多个,以上的sql只能查询一个号码的通话记录 一开始我想用游标实现,写一个游标,把被叫号码放入游标中,然后写一个循环,每次都依次查询一下, 但后来发现t_phonebill_201702数据量太大...后来查阅资料,多次尝试下写下这个sql,总算是实现了查询,实验论证效率也还不错。...,可以考虑使用简版,简版更易于了解,也能更清楚明白like多个值是如何实现的,但使用exists总是一个好习惯。

    4K10

    SQL为王:oracle标量子查询和表连接改写

    Oracle允许在select子句中包含单行子查询,这个也就是oracle的标量子查询,标量子查询有点类似于外连接,当使用到外连接时我们可以灵活的将其转化为标量子查询。...标量子查询其实还是一个子查询,那么它究竟是如何查询的:首先走的是外部的查询,比如上一个sql语句执行计划,先全表扫描的T2 a,然后取T2 a表的每一行数据就去和T1 b去过滤,过滤条件是a.owner...而如果标量子查询中如果主查询的一行对应子查询返回有多个值,这个是不允许的,看下面的例子 SQL> select a.username,b.object_id from t1 a,t2 b where a.username...关于标量子查询和表关联的性能简介: 如果主查询返回的数据较多,而子查询中又没有高效的索引,关联列对应的主查询表又没有较多的重复值,那么这个标量子查询的执行成本是很大的,如上面的标量子查询和外连接的sql...但是标量子查询oracle内部确是有优化的,优化器cache了中间的结果,如果结果集不大,子查询中又有高效的索引,那么这个标量子查询可能会比常规的表关联更加高效。

    4.3K60

    oracle 表的集合运算(联合查询)

    以前使用 ms sqlserver 的时候就用到过 union 关键字,将多条查询语句保存到一个列表中用程序来处理,这样可以让多个查询结果集合合并在一起,一般很少有这种需求,个人在使用的时候除非是子查询或多表查询实在无法实现的情况下才会用到...---- 集合运算要注意的问题 参与运算的各个集合必须列数相同且类型一致 采用第一个集合的表头作为最终结果的表头 如果使用了 order by,必须每个集合后面都使用 order by 可以使用小括号(...)先执行后面的语句 集合运算的几种方式 图片来自传智播客教师课件。...1、union/union all 并集 UNION运算符返回两个集合去掉重复元素后的所有记录。...,包括重复的。

    65430

    SQL 子查询怎么优化?写的很深!

    ---- 子查询 (Subquery)的优化一直以来都是 SQL 查询优化中的难点之一。关联子查询的基本执行方式类似于 Nested-Loop,但是这种执行方式的效率常常低到难以忍受。...它们二者所用的方法大同小异,基本思想是想通的。 本文的例子都基于 TPC-H 的表结构,这里 有一份供你参考。...子查询简介 子查询是定义在 SQL 标准中一种语法,它可以出现在 SQL 的几乎任何地方,包括 SELECT, FROM, WHERE 等子句中。...根据产生的数据来分类,子查询可以分成以下几种: 标量(Scalar-valued) 子查询:输出一个只有一行一列的结果表,这个标量值就是它的结果。如果结果为空(0 行),则输出一个 NULL。...如果不止一个子查询,则会产生多个 ALOJALOJ。必要的时候加上 Max1RowMax1Row 算子。 然后应用其他一些规则,将 ALOJALOJ 转换成 A×A×、A∃A∃、A∄A∄。

    4.4K30

    Oracle使用SQL语句查询表空间或数据库的增长量

    简介 在Oracle数据库中,我们有时候在分析一些问题时,需要了解哪一些表空间的数据增长了。我们需要快速定位数据量增长较快的用户表空间,或者在哪一些时间段表空间数据量突然飚增了。...如果在指定的PDB下执行的,只能查看当前PDB的表空间增长信息 set linesize 860; set pagesize 120; alter session set nls_date_format...比如提前分好了一个32GB的表空间,数据没存满前,文件大小不会变,但对象所占的空间是在增长的。...统计数据库数据量大小的 SQL 语句如下: -- 对象大小 select sum(t.bytes)/1024/1024/1024/1024 TB from dba_segments t; -- 数据文件大小...Oracle中并不会记录数据增长的历史,唯一一种可以近似得到数据增长历史的地方是v datafile统计的数据增长量如下: 图片 SQL语句为: SELECT trunc(t.creation_time

    4.9K20
    领券