执行计划小总结

1. why

工做中偶尔会遇到性能很差的复杂sql语句,在定位不了问题的状况下就须要执行计划出马了。mysql

2. what

执行计划顾名思义,就是oracle内部执行Sql语句的详细计划步骤。固然,其余数据库好比mysql、sqlsever等也有这个概念。本文以我经常使用的oracle为例。sql

3. how

如可查看执行计划?其实有不少种方法。数据库

最简单的,用IDE自带组件,好比sql developer上的查看执行计划按键(快捷键F10)oracle

稍微复杂点的,用代码查看:oop

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均可以发挥更好的性能。
相关文章
相关标签/搜索