执行计划小总结

1. why
工作中偶尔会遇到性能不好的复杂sql语句,在定位不了问题的情况下就需要执行计划出马了。
2. what
执行计划顾名思义,就是oracle内部执行Sql语句的详细计划步骤。当然,其他数据库比如mysql、sqlsever等也有这个概念。本文以我常用的oracle为例。
3. how
如可查看执行计划?其实有很多种方法。
最简单的,用IDE自带组件,比如sql developer上的查看执行计划按键(快捷键F10)
稍微复杂点的,用代码查看:
EXPLAIN PLAN FOR (SELECT * FROM TEMP);–方法1

SELECT plan_table_output FROM TABLE(DBMS_XPLAN.DISPLAY(‘PLAN_TABLE’));–方法2

SQL> select * from table(dbms_xplan.display);–方法3
4. then
解读执行计划join的时候,有三种方式:hash join、 merge join、nested loop

A、B两表谁在前谁在后并不影响执行计划,计划会自动算出最优的执行方法
当nested loop,最优执行计划一般是小表作为驱动表只遍历一遍。
Nested loop一般用在连接的表中有索引,并且索引选择性较好的时候;Hash join在两个表的数据量差别很大的时候.Sort Merge join 用在没有索引,并且数据已经排序的情况.
通常来讲,能够使用merge join的地方,hash join都可以发挥更好的性能。

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理