首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

深入SQL执行计划之CBO查询转换(7):Distinct 配置最优机能(Distinct Placement)

编者按: 本文作者系杨昱明,现就职于甲骨文公司,从事数据库方面的技术支持。希望能通过发表文章,把一些零散的知识再整理整理。...编辑|SQL和数据库技术(ID:SQLplusDB) CBO 查询转换系列(深入了解Oracle执行计划) CBO 查询转换(1):子查询展开机能(Subquery Unnesting) CBO 查询转换...By 配置最优机能(Group By Placement) CBO查询转换(5):星型转换(Star Transformation) CBO查询转换(6):子查询关联集展开机能(unnest correlation...set subquery) 同之前聊过的 Group By 配置最优机能同等的,还有 Distinct 配置最优机能(Distinct Placement)。...关闭此功能的方法是 "_optimizer_distinct_placement" = false。

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

MYSQL 查询优化之路-之DISTINCT全表扫描

背景:今天对一个20w的表做关联查询,创建各种索引,没有提高执行的效率,使用EXPLAIN检查,总是提示“Using temporary”全表扫描,这不是我想的。...通过度娘,各种百度,是因为DISTINCT使用了全表扫描,现在特别记录下来。以背查验。...[驱动表] 的定义为:1)指定了联接条件时,满足查询条件的记录行数少的表为[驱动表];2)未指定联接条件时,行数少的表为[驱动表](Important!)。...e.NestedLoopJoin实际上就是通过驱动表的结果集作为循环基础数据,然后一条一条的通过该结果集中的数据作为过滤条件到下一个表中查询数据,然后合并结果。...如果还有第三个参与Join,则再通过前两个表的Join结果集作为循环基础数据,再一次通过循环查询条件到第三个表中查询数据,如此往复 2.两表JOIN优化: a.当无order by条件时

4.2K42

突破常识:SQL增加DISTINCT查询效率反而提高

以前也经常发现由于开发人员对SQL不是很理解,在SELECT列表的20多个字段前面添加了DISTINCT,造成查询的执行异常缓慢,基本上很难在ORA-1555错误出现之前得到查询的结果,甚至有些SQL会产生...不过这次碰到了一个有趣的现象:开发人员在测试一个比较复杂的SQL时发现如果SQL中加上了DISTINCT,则查询大概要花费4分钟左右;而如果不加DISTINCT,则查询执行了10多分钟仍然没有返回结果。...根据这样的描述,首先想到的是可能DISTINCT是在查询的最内层,由于加上DISTINCT使得第一步的结果集缩小了,从而导致查询性能的提高。但一看SQL才发现,DISTINCT居然是在查询的最外层。...对于不加DISTINCT的情况:由于使用IN子查询,Oracle对第二个连接采用了HASH JOIN SEMI,这种方式相对于普通的HASHJOIN来说代价要大一些。...这就是增加一个DISTINCT操作,查询效率反而提高的真正原因。 最后要说明一点,举这个例子意在说明:优化时没有什么东西是一成不变的,几乎任何事情都有可能发生,不要被一些所谓规则限制住。

3K60

SQL命令 DISTINCT

但是,嵌入式SQL基于游标的查询可以返回多行数据;在基于游标的查询中,DISTINCT子句只返回唯一值行。 DISTINCT和ORDER BY DISTINCT子句在ORDER BY子句之前应用。...未使用优化. */ 可以使用管理门户优化包含DISTINCT子句的查询查询性能。依次选择系统管理、配置、SQL和对象设置、SQL。...子查询:在子查询中使用DISTINCT子句是合法的,但没有意义,因为子查询返回单个值。 未选择行数据:DISTINCT子句可以与不访问任何表数据的SELECT一起使用。...DISTINCT和%ROWID 指定DISTINCT关键字会导致基于游标的嵌入式SQL查询不设置%ROWID变量。即使DISTINCT不限制返回的行数,也不设置%ROWID。...动态SQL SELECT查询和非游标嵌入式SQL SELECT查询从未设置%ROWID。 DISTINCT和事务处理 指定DISTINCT关键字会导致查询检索所有当前数据,包括当前事务尚未提交的数据。

4.3K10

数据库-多表查询-连接查询

数据库-多表查询-连接查询 同时查询多张表获取到需要的数据 比如:我们想查询到开发部有多少人,需要将部门表和员工表同时进行查询 多表查询的分类: 准备数据 -- 创建部门表 create table...-- 只查询一张表不能查询出员工名字和部门名字,需要使用多表操作 select * from emp, dept; 完成多表操作的两种方式: 表连接 子查询 1....,显示员工id,姓名,性别,工资和所在的部门名称 确定查询哪些表 确定表连接条件,员工表.dept_id = 部门表.id 的数据才是有效的 确定查询条件,我们查询的是唐僧的信息,员工表.name='唐僧...联合查询 Union (Mysql 支持) Mysql 为了查询所有表的关联数据,可以将左右连接的查询 联合一起来执行。...语法格式: -- 使用union联合合并左右外连接的查询结果,就是相当于全外连接查询了。

13.5K20

数据库,单表查询,多表查询,子查询

数据库查找方式进阶 一.单表查询 1.查看表单选择段落 1.disinct 所有内容去重:select disinct * from 表名称; 指定字段去重:select disinct 字段 from..........) as 新名字 2.in关键字查询 "查询平均年龄大于25的部门名称 子查询方式: 平均年龄大于25的部门id有哪些?...筛选出平均年龄大于25的部门id 拿着部门id 去查询部门表查询" select name from dept where id in (select dept_id from emp group...on emp.dept_id = dept.id group by dept.name having avg(age) >25; 3.exists关键字查询 xists 后跟子查询查询有结果是为...既然是表就能链接起来 #综合练习: "查询每个部门工资最高的员工信息 先查询每个部门的最高工资 将查询结果与员工表联合起来 在加条件判断部门id相同并且 最高工资相同 则显示" select *from

5.3K40
领券