no_expand优化案例
bond 来看一个烂语句:
select a.*,b.dn from temp_allcrmuser a, phs_smc_user b
where a.USERNUMBER=b.dn
and (a.ACTFLAG<>b.ACT_FLG
or a.ENABLEFLAG<>b.ENABLE_FLG);
汽水 15:50:29
但是对你自己做实验,搞工作极其有利
bond15:50:34
-------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 2 | 112 | 12 (17)| 00:00:01 |
| 1 | CONCATENATION | | | | | |
| 2 | MERGE JOIN | | 1 | 56 | 6 (17)| 00:00:01 |
| 3 | TABLE ACCESS BY INDEX ROWID| PHS_SMC_USER | 22 | 396 | 3 (0)| 00:00:01 |
| 4 | INDEX FULL SCAN | IND_SMC_USER_DN | 22 | | 1 (0)| 00:00:01 |
|* 5 | FILTER | | | | | |
|* 6 | SORT JOIN | | 82 | 3116 | 3 (34)| 00:00:01 |
| 7 | TABLE ACCESS FULL | TEMP_ALLCRMUSER | 82 | 3116 | 2 (0)| 00:00:01 |
| 8 | MERGE JOIN | | 1 | 56 | 6 (17)| 00:00:01 |
| 9 | TABLE ACCESS BY INDEX ROWID| PHS_SMC_USER | 22 | 396 | 3 (0)| 00:00:01 |
| 10 | INDEX FULL SCAN | IND_SMC_USER_DN | 22 | | 1 (0)| 00:00:01 |
|* 11 | FILTER | | | | | |
|* 12 | SORT JOIN | | 82 | 3116 | 3 (34)| 00:00:01 |
| 13 | TABLE ACCESS FULL | TEMP_ALLCRMUSER | 82 | 3116 | 2 (0)| 00:00:01 |
-------------------------------------------------------------------------------------------------
bond(510330025) 15:50:48
5 - filter("A"."ENABLEFLAG"<>"B"."ENABLE_FLG")
6 - access("A"."USERNUMBER"="B"."DN")
filter("A"."USERNUMBER"="B"."DN")
11 - filter("A"."ACTFLAG"<>"B"."ACT_FLG" AND LNNVL("A"."ENABLEFLAG"<>"B"."ENABLE_FLG"))
12 - access("A"."USERNUMBER"="B"."DN")
filter("A"."USERNUMBER"="B"."DN")
SELECT *
FROM (SELECT rownum,
a.owner AS owner_a,
b.owner AS owner_b,
a.object_id AS object_id_a,
b.object_id AS object_id_b,
a.object_name
FROM test1 a
INNER JOIN test2 b
ON b.object_name = a.object_name)
WHERE (owner_a <> owner_b OR object_id_a <> object_id_b)
重庆-有教无类16:23:11
这个它改不了了
重庆-有教无类 16:26:13
咋样
重庆-有教无类16:26:17
还con不
bond 16:27:17
==
bond 16:30:59
select * from
(
select rownum a_rownum,a.ACTFLAG a_ACTFLAG,a.ENABLEFLAG a_ENABLEFLAG,b.dn,b.ACT_FLG b_ACT_FLG,b.ENABLE_FLG b_ENABLE_FLG
from temp_allcrmuser a
join phs_smc_user b
on a.USERNUMBER=b.dn) t
where (a_ACTFLAG<>b_ACT_FLG or a_ENABLEFLAG<>b_ENABLE_FLG);
----------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
----------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 22 | 1694 | 8740 (6)| 00:01:45 |
|* 1 | VIEW | | 22 | 1694 | 8740 (6)| 00:01:45 |
| 2 | COUNT | | | | | |
|* 3 | HASH JOIN | | 22 | 1232 | 8740 (6)| 00:01:45 |
| 4 | TABLE ACCESS FULL| PHS_SMC_USER | 22 | 396 | 12 (0)| 00:00:01 |
| 5 | TABLE ACCESS FULL| TEMP_ALLCRMUSER | 10M| 394M| 8571 (4)| 00:01:43 |
--------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
1 - filter("A_ACTFLAG"<>"B_ACT_FLG" OR "A_ENABLEFLAG"<>"B_ENABLE_FLG")
3 - access("A"."USERNUMBER"="B"."DN")
bond 16:31:05
靠,可以了
bond 16:31:18
就是因为rownum?
史狮16:31:22
太牛b
。。。。。省略。。。。。
select /*+ Use_hash(a,b) no_expand*/ a.*,b.dn from temp_allcrmuser a, phs_smc_user b
where a.USERNUMBER=b.dn
and (a.ACTFLAG<>b.ACT_FLG
or a.ENABLEFLAG<>b.ENABLE_FLG);
--------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 18 | 1008 | 8740 (6)| 00:01:45 |
|* 1 | HASH JOIN | | 18 | 1008 | 8740 (6)| 00:01:45 |
| 2 | TABLE ACCESS FULL| PHS_SMC_USER | 22 | 396 | 12 (0)| 00:00:01 |
| 3 | TABLE ACCESS FULL| TEMP_ALLCRMUSER | 10M| 394M| 8571 (4)| 00:01:43 |
--------------------------------------------------------------------------------------
用no_expand HINT也可以
在ORACLE11g 之前,CBO 还是会犯SB ,11g之后 不会自动的 expand了,
注意,上面都是我的学生
no_expand优化案例的更多相关文章
- 数据库优化案例——————某市中心医院HIS系统
记得在自己学习数据库知识的时候特别喜欢看案例,因为优化的手段是容易掌握的,但是整体的优化思想是很难学会的.这也是为什么自己特别喜欢看案例,今天也开始分享自己做的优化案例. 最近一直很忙,博客产出也少的 ...
- mysql优化案例
MySQL优化案例 Mysql5.1大表分区效率测试 Mysql5.1大表分区效率测试MySQL | add at 2009-03-27 12:29:31 by PConline | view:60, ...
- SQL 优化案例 1
create or replace procedure SP_GET_NEWEST_CAPTCHA( v_ACCOUNT_ID in VARCHAR2, --接收短信的手机号 v_Tail_num i ...
- 老李案例分享:Weblogic性能优化案例
老李案例分享:Weblogic性能优化案例 POPTEST的测试技术交流qq群:450192312 网站应用首页大小在130K左右,在之前的测试过程中,其百用户并发的平均响应能力在6.5秒,性能优化后 ...
- Hive优化案例
1.Hadoop计算框架的特点 数据量大不是问题,数据倾斜是个问题. jobs数比较多的作业效率相对比较低,比如即使有几百万的表,如果多次关联多次汇总,产生十几个jobs,耗时很长.原因是map re ...
- 数据库优化案例——————某知名零售企业ERP系统
写在前面 记得在自己学习数据库知识的时候特别喜欢看案例,因为优化的手段是容易掌握的,但是整体的优化思想是很难学会的.这也是为什么自己特别喜欢看案例,今天也分享自己做的优化案例. 之前分享过OA系统.H ...
- Spark集群之yarn提交作业优化案例
Spark集群之yarn提交作业优化案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.启动Hadoop集群 1>.自定义批量管理脚本 [yinzhengjie@s101 ...
- MySQL参数优化案例
环境介绍 优化层级与指导思想 优化过程 最小化安装情况下的性能表现 优化innodb_buffer_pool_size 优化innodb_log_files_in_group&innodb_l ...
- MySQL的索引单表优化案例分析
建表 建立本次优化案例中所需的数据库及数据表 CREATE DATABASE db0206; USE db0206; CREATE TABLE `db0206`.`article`( `id` INT ...
随机推荐
- Leetcode680.Valid Palindrome II验证回文字符串2
给定一个非空字符串 s,最多删除一个字符.判断是否能成为回文字符串. 示例 1: 输入: "aba" 输出: True 示例 2: 输入: "abca" 输出: ...
- SpringMvc表单标签库
HTML密码框 <td><form:label path="password">密码:</form:label></td><t ...
- GeoServer手动发布本地Shapefile地图
首先,本文实现的结果图给大家展现一下: 放大的样子: 颜色是通过属性中某个字段值来分级的,可以自定义. 上面功能是用ArcGIS切片好数据,在Geoserver 中发布,并用google地图作为底图展 ...
- 使用JS如何消除一个数组里重复的元素
JS: var arrData = [1,3,5,7,7,8,9,3,10,8,"sdsdsds","sss","ffff","s ...
- 【JZOJ3854】【NOIP2014八校联考第2场第2试9.28】分组(group)
MEi Bsny所在的精灵社区有n个居民,每个居民有一定的地位和年龄,ri表示第i个人的地位,ai表示第i个人的年龄. 最近社区里要举行活动,要求几个人分成一个小组,小组中必须要有一个队长,要成为队长 ...
- 通过IP地址訪问Jbossserver上的应用
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/liu765023051/article/details/28882533 环境介绍 Web项目中.在 ...
- MUI - H5实现ios长按图标后进入图标排序及删除功能的效果
html5实现ios长按图标后进入图标排序及删除功能的效果 我们知道在ios(国产定制安卓系统基本都有)设备上按下图标,图标就会不停的抖动,并且可以随心拖动排序和删除. 那么问题来了,我们怎么通过ht ...
- Python学习之路1☞简介及入门代码
在学习之前,首先了解一下python的前世今生 一.python简介与发展: python 是一种面向对象的解释性计算机程序设计语言. python由荷兰人Guido van Rossum 于1989 ...
- 2019-3-21-win10-uwp-修改图片质量压缩图片
title author date CreateTime categories win10 uwp 修改图片质量压缩图片 lindexi 2019-03-21 15:29:20 +0800 2019- ...
- @codeforces - 444A@ DZY Loves Physics
目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定一个 n 点 m 边的图,边有边权,点有点权. 找到一个连通 ...