sql – Oracle 11g – 如何优化慢速并行插入选择?

前端之家收集整理的这篇文章主要介绍了sql – Oracle 11g – 如何优化慢速并行插入选择?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我们想加快下面的并行插入语句的运行.我们期望插入大约80M的记录,大约需要2个小时才能完成.
INSERT /*+ PARALLEL(STAGING_EX,16) APPEND NOLOGGING */ INTO STAGING_EX (ID,TRAN_DT,RECON_DT_START,RECON_DT_END,RECON_CONFIG_ID,RECON_PM_ID) 
SELECT /*+PARALLEL(PM,16) */ SEQ_RESULT_ID.nextval,sysdate,'8a038312403e859201405245eed00c42',T1.ID FROM PM T1 WHERE STATUS = 1 and not 
exists(select 1 from RESULT where T1.ID = RECON_PM_ID and CREATE_DT >= sysdate - 60) and 
UPLOAD_DT >= sysdate - 1 and (FUND_SRC_TYPE = :1)

我们认为缓存not exists列的结果会加快插入速度.我们如何执行缓存?有什么想法加快插入速度?

请参阅以下有关企业管理器的计划统计信息.我们还注意到这些语句没有并行运行.这是正常的吗?

编辑:顺便说一下,序列已经缓存到1M

解决方法

尝试使用更多绑定变量,尤其是在可能发生嵌套循环的情况下.我注意到你可以在像这样的情况下使用它
CREATE_DT >= :YOUR_DATE instead of CREATE_DT >= sysdate - 60

我认为这可以解释为什么在执行计划的最低部分有1.8亿次执行,即使更新查询的其他部分仍然是7900万中的800万.

猜你在找的MsSQL相关文章