博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
执行计划小总结
阅读量:6879 次
发布时间:2019-06-26

本文共 674 字,大约阅读时间需要 2 分钟。

1. why

工作中偶尔会遇到性能不好的复杂sql语句,在定位不了问题的情况下就需要执行计划出马了。

2. what

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

3. how

如可查看执行计划?其实有很多种方法。

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

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

EXPLAIN PLAN FOR (SELECT * FROM TEMP);--方法1SELECT plan_table_output FROM TABLE(DBMS_XPLAN.DISPLAY('PLAN_TABLE'));--方法2SQL> 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都可以发挥更好的性能。

转载地址:http://abgfl.baihongyu.com/

你可能感兴趣的文章
我的友情链接
查看>>
lvm
查看>>
CentOS6.5下安装tomcat7
查看>>
为程序设置超时
查看>>
通过持续ping来检测网络质量
查看>>
win2008 R2 添加ftp
查看>>
轻松使用PL/SQL的数组
查看>>
记一次修改sga大小之后出现的一系列报错
查看>>
解决打开文件夹是打开方式
查看>>
Android常用的一些服务demo源码
查看>>
Linux中Shell简介
查看>>
天狗论坛——论坛为什么选用 Amaze UI?
查看>>
JAVA_OPTS, JAVA_TOOL_OPTIONS,_JAVA_OPTIONS傻傻分不清楚
查看>>
SpringMVC结合Ajaxfileupload异步多文件上传至远程服务器
查看>>
Oracle的REDO和UNDO
查看>>
最新推出SAP ECC EHP7最新版本IDES带演示数据,带开发ACCESS KEY。
查看>>
详细探究Spark的shuffle实现
查看>>
云桌面技术展望
查看>>
openstack 制作winserver2008_R2镜像 用cloudbase-init 实现第一次创建就注入密码(需登录)...
查看>>
Tengine (淘宝nginx ) + tomcat 安装整合 后篇+ 高可用和负载均衡
查看>>