失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > hint用法mysql 使用hint优化Oracle的执行计划

hint用法mysql 使用hint优化Oracle的执行计划

时间:2021-04-24 22:24:32

相关推荐

hint用法mysql 使用hint优化Oracle的执行计划

背景: 某表忽然出现查询非常缓慢的情况,cost 100+ 秒以上;严重影响生产。 Oracle入门教程:leading vs ordered hint http://

背景:

某表忽然出现查询非常缓慢的情况,,cost 100+ 秒以上;严重影响生产。

Oracle入门教程:leading vs ordered hint

Oracle hint 实践一列 leanding 驱动表和hash多块读取

Oracle优化常用hint语句

Oracle调优hint提示

原SQL:

explain plan for

select * from (

select ID id,RET_NO retNo, FROM_SYS fromSy, TO_SYS toSys, COMMAND_CODE commandCode, COMMAND, STATUS,

EXT_CODE, ORIGN_CODE orignCode,error_message errorMessage, RE_F, RET_MSG retMsg

from interface_table where ((command_code in('AASSS')

and status in('F','E') and (re_f = 'N') and FROM_SYS = 'MEE')

or (COMMAND_CODE in('XXXX','XXXX9') and FROM_SYS = 'EXT' and RE_F = 'N')

) and MOD(id, 1) = 0 order by id) where rownum <= 100 ;

查看其执行计划:

SELECT plan_table_output FROM TABLE(DBMS_XPLAN.DISPLAY('PLAN_TABLE'));

优化后的SQL:

explain plan for

select * from (

select /*+ index(INT_TABLE IX_INT_TABLE_2)*/ ID id,RET_NO retNo, FROM_SYS fromSy, TO_SYS toSys, COMMAND_CODE commandCode, COMMAND, STATUS,

EXT_CODE, ORIGN_CODE orignCode,error_message errorMessage, RE_F, RET_MSG retMsg

from interface_table where ((command_code in('AASSS')

and status in('F','E') and (re_f = 'N') and FROM_SYS = 'MEE')

or (COMMAND_CODE in('XXXX','XXXX9') and FROM_SYS = 'EXT' and RE_F = 'N')

) and MOD(id, 1) = 0 order by id) where rownum <= 100 ;

查看其执行计划:

SELECT plan_table_output FROM TABLE(DBMS_XPLAN.DISPLAY('PLAN_TABLE'));

比较:

查看执行计划,原来是使用 full scan - 当数据量大时非常慢;优化后oracle优先走range scan,hint 的 index 是未处理标识字段的索引,正常情况下这个数据集合相对较小--------所以可以达到优化目的。

具体情况具体分析,我们必须要看实际的表存的业务数据,分析其业务关系找到最小业务集合;后者要看懂执行计划,根据rows, bytes, cost, time 找到最优项目。这个分析顺序不能倒置。

问题:为何使用 rownum 后,oracle执行计划会走full scan?

本文永久更新链接地址:

发布php中文网,转载请注明出处,感谢您的尊重!

如果觉得《hint用法mysql 使用hint优化Oracle的执行计划》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。