用Merge来改写相关更新的例子
下面的两个SQL是等价的,但是一个执行N小时都执行不完,一个花了一分钟。 执行计划显示
第一个语句是由外面的即将被更新的表驱动内层,相对于是一个NEST LOOP,cost非常大。
第二个语句是内层单独执行完后,与外面的筛选结果做一个HASH JOIN, cost降低了很多. UPDATE GPCOMP1.GPRECL R SET (PROMISED_BY,PROMISED_DATE)=(SELECT W.USER_ID,W.CREATED_ON FROM
(SELECT T.*,ROWNUM FROM (
SELECT A.USER_ID,A.CREATED_ON,RL.TRAN_ID,ROW_NUMBER() OVER(PARTITION BY A.CUSTNO ORDER BY A.ACTIVITY_ID DESC) RN
FROM GPCOMP1.GPRECL RL,GPCOMP1.GPACTV A
WHERE A.CUSTNO = RL.CUSTNO AND A.ACTVDATE < RL.RCLDATE AND RL.PROMISED ='Y'
) T WHERE T.RN =1) W WHERE W.TRAN_ID=R.TRAN_ID
) WHERE R.PROMISED ='Y'; PLAN_TABLE_OUTPUT
-----------------------------------------------------------------------------------------------------------------------------------
Plan hash value: 2415251688
--------------------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes |TempSpc| Cost (%CPU)| Time |
--------------------------------------------------------------------------------------------------------------------------
| 0 | UPDATE STATEMENT | | 19278 | 433K| | 1712M (1)|999:59:59 |
| 1 | UPDATE | GPRECL | | | | | |
| 2 | TABLE ACCESS BY INDEX ROWID | GPRECL | 19278 | 433K| | 9334 (1)| 00:01:53 |
|* 3 | INDEX RANGE SCAN | GPRCL_PROMISED_CUST_TRAN | 19278 | | | 103 (0)| 00:00:02 |
|* 4 | VIEW | | 338K| 11M| | 44419 (1)| 00:08:54 |
| 5 | COUNT | | | | | | |
|* 6 | VIEW | | 338K| 15M| | 44419 (1)| 00:08:54 |
|* 7 | WINDOW SORT PUSHED RANK | | 338K| 22M| 28M| 44419 (1)| 00:08:54 |
| 8 | NESTED LOOPS | | 338K| 22M| | 38703 (1)| 00:07:45 |
|* 9 | INDEX RANGE SCAN | GPRCL_PROMISED_CUST_TRAN | 19278 | 508K| | 103 (0)| 00:00:02 |
|* 10 | TABLE ACCESS BY INDEX ROWID| GPACTV | 18 | 792 | | 3 (0)| 00:00:01 |
|* 11 | INDEX RANGE SCAN | GPACTV_CUSTNO_TRUNC_ACTVDATE | 1 | | | 2 (0)| 00:00:01 |
--------------------------------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
3 - access("R"."PROMISED"='Y')
4 - filter("W"."TRAN_ID"=:B1)
6 - filter("T"."RN"=1)
7 - filter(ROW_NUMBER() OVER ( PARTITION BY "A"."CUSTNO" ORDER BY INTERNAL_FUNCTION("A"."ACTIVITY_ID") DESC)<=1)
9 - access("RL"."PROMISED"='Y')
10 - filter("A"."ACTVDATE"<"RL"."RCLDATE")
11 - access("A"."CUSTNO"="RL"."CUSTNO" AND TRUNC(INTERNAL_FUNCTION("ACTVDATE"),'fmddd')<=TRUNC(INTERNAL_FUNCTION("RL"."RCLDATE"),'fmddd')) MERGE INTO GPCOMP1.GPRECL R USING (SELECT T.USER_ID,T.CREATED_ON,T.ID FROM (
SELECT A.USER_ID,A.CREATED_ON,RL.ROWID AS ID,ROW_NUMBER() OVER(PARTITION BY A.CUSTNO ORDER BY A.ACTIVITY_ID DESC) RN
FROM GPCOMP1.GPRECL RL,GPCOMP1.GPACTV A
WHERE A.CUSTNO = RL.CUSTNO AND A.ACTVDATE < RL.RCLDATE AND RL.PROMISED ='Y') T
WHERE T.RN =1) W
ON (W.ID=R.ROWID AND R.PROMISED ='Y')
WHEN MATCHED THEN
UPDATE SET R.PROMISED_BY = W.USER_ID, R.PROMISED_DATE=W.CREATED_ON; PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------------------------------------
Plan hash value: 1259882673
--------------------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes |TempSpc| Cost (%CPU)| Time |
--------------------------------------------------------------------------------------------------------------------------
| 0 | MERGE STATEMENT | | 3194 | 112K| | 56039 (1)| 00:11:13 |
| 1 | MERGE | GPRECL | | | | | |
| 2 | VIEW | | | | | | |
|* 3 | HASH JOIN | | 3194 | 1394K| 7760K| 56039 (1)| 00:11:13 |
| 4 | TABLE ACCESS BY INDEX ROWID | GPRECL | 19278 | 7530K| | 9334 (1)| 00:01:53 |
|* 5 | INDEX RANGE SCAN | GPRCL_PROMISED_CUST_TRAN | 19278 | | | 103 (0)| 00:00:02 |
|* 6 | VIEW | | 338K| 15M| | 45379 (1)| 00:09:05 |
|* 7 | WINDOW SORT PUSHED RANK | | 338K| 27M| 33M| 45379 (1)| 00:09:05 |
| 8 | NESTED LOOPS | | 338K| 27M| | 38703 (1)| 00:07:45 |
|* 9 | INDEX RANGE SCAN | GPRCL_PROMISED_CUST_TRAN | 19278 | 602K| | 103 (0)| 00:00:02 |
|* 10 | TABLE ACCESS BY INDEX ROWID| GPACTV | 18 | 954 | | 3 (0)| 00:00:01 |
|* 11 | INDEX RANGE SCAN | GPACTV_CUSTNO_TRUNC_ACTVDATE | 1 | | | 2 (0)| 00:00:01 |
--------------------------------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
3 - access("T"."ID"="R".ROWID)
5 - access("R"."PROMISED"='Y')
6 - filter("T"."RN"=1)
7 - filter(ROW_NUMBER() OVER ( PARTITION BY "A"."CUSTNO" ORDER BY INTERNAL_FUNCTION("A"."ACTIVITY_ID") DESC)<=1)
9 - access("RL"."PROMISED"='Y')
10 - filter(TRUNC(INTERNAL_FUNCTION("ACTVDATE"))<=TRUNC(INTERNAL_FUNCTION("RL"."RCLDATE")) AND "A"."ACTVDATE"<"RL"."RCLDATE")
11 - access("A"."CUSTNO"="RL"."CUSTNO" AND TRUNC(INTERNAL_FUNCTION("ACTVDATE"),'fmddd')<=TRUNC(INTERNAL_FUNCTION("RL"."RCLDATE"),'fmddd'))
用Merge来改写相关更新的例子的更多相关文章
- mysql联合查询更新数据库例子
mysql联合查询更新数据库例子,用户表,部门表,把用户表中的部门属性更新为部门表的主键UPDATE user_table AS utINNER JOIN belongdept AS bd ON bd ...
- Microsoft Dynamics CRM 2013 的相关更新 2013-12
DCRM 2013已经发布一段时间了,很多同学都在学习实践中. 截至目前,已经有了一些相关的更新,具体内容,可以参见web Page:http://blogs.msdn.com/b/c ...
- PLSQL_性能优化系列17_Oracle Merge Into和Update更新效率
2015-05-21 Created By BaoXinjian 一.摘要 以前只考虑 merge into 只是在特定场合下方便才使用的,今天才发现,merge into 竟然会比 update 在 ...
- 利用Merge into 改写Update SQL 一例
前言 客户说,生产系统最近CPU使用率经常达到100%,请DBA帮忙调查一下. 根据客户提供的情况描述及对应时间段,我导出AWR,发现如下问题: 11v41vaj06pjd :每次执行消耗2,378, ...
- HOOK相关原理与例子
消息HOOK 原理: 1. 用户输入消息,消息被放到系统消息队列. 2. 程序发生了某些需要获取输入的事件,就从系统消息队列拿出消息放到程序消息队列中. 3. 应用程序检测到有新的消息进入到程序消息队 ...
- cocos2d-x 2.2 资源更新AssetsManager例子代码
转自:http://www.58player.com/blog-2327-601.html // // UpgradeLayer.h // AmazeDemo // // Created by lsw ...
- ORACLE 关连更新 update select
总结: 关键的地方是where 语句的加入. 在11G中, 如果不加11G , 或造成除匹配的行数更新为相应的值之后, 其余的会变成负数. 所以, 测试的办法就是: 先查看需要更新的数量即连接的数 ...
- ORACLE 通过连接查询更新 update select
注意: 关键的地方是where 语句的加入. 在11G中, 如果不加11G , 或造成除匹配的行数更新为相应的值之后, 其余的会变成负数. 所以,执行前需要测试, 普通办法就是: 先查看需要更新的 ...
- [转]oracle update set select from 关联更新
本文转自:http://blog.csdn.net/disiwei1012/article/details/52589181 http://www.blogjava.net/Jhonney/archi ...
随机推荐
- HTML表单提交
<!DOCTYPE html> <!--当前文档为html5--> <html> <head> <!--设置文档编码--> <meta ...
- IBM x3850 x5 服务器 安装 Windows Server 2008
一.硬件需求 一个8G以上的U盘 二.软件需求 1.Windwos Server 2008镜像 2.系统启动盘制作工具Ultraiso 3.IBM ServerGuide引导镜像 三.制作及安装步骤 ...
- JAVA基础中的注意点(二)
1.数组 a.特点:同种数据类型:数组类型一旦确定就不能改变. 连续空间存放:数据空间是连续的. 空间长度:数组有自己的长度,初始化的时候需要定义. 数组的下标:从0开始,第一个数组元素下标为0,最后 ...
- winform用户控件、动态创建添加控件、timer控件、控件联动
用户控件: 相当于自定义的一个panel 里面可以放各种其他控件,并可以在后台一下调用整个此自定义控件. 使用方法:在项目上右键.添加.用户控件,之后用户控件的编辑与普通容器控件类似.如果要在后台往窗 ...
- python 异常
引用一段来自菜鸟教程的文章:http://www.runoob.com/python/python-exceptions.html Python 异常处理 python提供了两个非常重要的功能来处理p ...
- Ecplise真机调试(Android)
手机连电脑: 利用豌豆荚等工具安装驱动: 安卓手机打开开发人员选项,usb调试: 可以在cmd中执行sdk文件夹中的adb查看是否连接成功://adb devices 可将adb.exe所在文件路径加 ...
- NOI 2010 海拔 ——平面图转对偶图
[题目分析] 可以知道,所有的海拔是0或1 最小割转最短路,就可以啦 SPFA被卡,只能换DIJ [代码] #include <cstdio> #include <cstring&g ...
- BZOJ3752 : Hack
折半爆搜,首先爆搜出所有长度不超过$4$的串. 对于每个询问,首先暴力枚举所有长度不超过$4$的串,以及前$4$位相同时后面的串. 然后枚举前$4$位,以及后面的串长,那么后面的hash值唯一,可以双 ...
- Linux CentOS下安装Oracle
1 .在安装oracle之前首先安装以下组件包,直接输入下列语句安装. yum install binutils* -y yum install compat-lib* -y yum install ...
- Ubuntu 16.04 install 搜狗输入法
1.#先添加以下源 sudo add-apt-repository ppa:fcitx-team/nightly 2.#添加源之后需要更新一下系统 sudo apt-get update 3.#开始安 ...