执行计划小总结

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都可以发挥更好的性能。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值