EXPLAIN PLAN获取SQL语句执行计划】的更多相关文章

一.获取SQL语句执行计划的方式 1. 使用explain plan 将执行计划加载到表plan_table,然后查询该表来获取预估的执行计划 2. 启用执行计划跟踪功能,即autotrace功能 3. 使用PL/SQL Developer提供的获取执行计划方法 - F5键 4. 查询动态性能视图v$sql_plan,v$sql_plan_statistics,v$sql_workarea 等来获取已缓存到库缓存中的真实执行计划 5. 查询自动工作量资料库(Automatic Workload…
通常我们查看SQL语句的执行计划都是通过EXPLAIN PLAN或者AUTOTRACE来完成.但是这些查看方法有一个限制,它们都是人为触发而产生的,无法获得数据库系统中曾经执行过的SQL语句执行计划. V$SQL_PLAN视图弥补了这个这个功能缺陷.使用这个视图可以获得当前数据库实例library cache中保存的SQL执行计划.由于是在内存中保存的,因此这个视图所能查看的信息也有限制,如果信息已被换出内存,将无法查看到. 这里给出V$SQL_PLAN视图的使用方法. 1.准备测试环境sys@…
1.建立表索引 create index 索引名 on 表名(列名,列名); 2.删除表索引 drop index 索引名 on 表名; 3.查看表索引 select * from sysibm.sysindexes where tbname='表名';   ---表名区分大小写 或者在后台可以用: describe indexes for table 表名; 4.查看SQL语句执行计划 db2expln -d 库名 -f test.sql -t -g -z ";" > test…
EXPLAIN PLAN 是一个很好的分析SQL语句的工具,它甚至可以在不执行SQL的情况下分析语句. 通过分析,我们就可以知道ORACLE是怎么样连接表,使用什么方式扫描表(索引扫描或全表扫描)以及使用到的索引名称. 你需要按照从里到外,从上到下的次序解读分析的结果. EXPLAIN PLAN分析的结果是用缩进的格式排列的, 最内部的操作将被最先解读, 如果两个操作处于同一层中,带有最小操作号的将被首先执行. NESTED LOOP是少数不按照上述规则处理的操作, 正确的执行路径是检查对NES…
From : http://blog.csdn.net/radkitty/article/details/4632289 要使用该功能,mysql的版本必须在5.0.37版本以上.否则只能使用explain 的方式来检查. profiling 功能可以了解到cpu io 等更详细的信息. show profile 的格式如下: SHOW PROFILE [type [, type] ... ]    [FOR QUERY n]    [LIMIT row_count [OFFSET offset…
explain select * from film where rating>9\G; select_type 表示select的类型 SIMPLE 代表简单表,不用表连接或子查询 PRIMRY 主查询(外层查询) UNION UNION中的第二个或者后面的查询语句 SUBQUERY 子查询中的第一个SELECT table 输出结果集的表   possible_keys 查询中可能用到的索引   key 查询中实际用到的索引   key_len 索引的长度   rows 扫描的行数   ty…
每个列的简单解释如下:  select_type:表示 SELECT 的类型,常见的取值有 SIMPLE(简单表,即不使用表连接 或者子查询).PRIMARY(主查询,即外层的查询).UNION(UNION 中的第二个或者后面的查询语句).SUBQUERY(子查询中的第一个 SELECT)等.  table:输出结果集的表.  type:表示表的连接类型,性能由好到差的连接类型为 system(表中仅有一行,即常量表).const(单表中最多有一个匹配行,例如 primary key 或者…
获取SQL执行计划的方式有很多,但是某些时候获取的SQL执行计划并不是准确的,只有在SQL真实执行之后获取到的SQL PLAN才是真实准确的,其他方式(如,explain plan)获取到的执行计划都有可能因为绑定绑定变量和当时SQL执行环境的影响而导致获取到的执行计划可能不准确.对于AUTOTRACE开关,当执行SET AUTOT ON和SET AUTOT TRACE命令此时的SQL是实际执行过的,所以此时获取到的执行计划是准确的.而SET AUTOT TRACE EXP命令时稍有不同,当执行…
摘要: 本文着重介绍 DRDS 执行计划中各个操作符的含义,以便用户通过查询计划了解 SQL 执行流程,从而有针对性的调优 SQL. DRDS分布式SQL引擎 — 执行计划介绍 前言 数据库系统中,执行计划是对 SQL 如何执行的形式化表示,往往由若干关系操作符构成,用户可以通过对应的 EXPLAIN 命令查看,并通过执行计划大致了解 SQL 的执行过程和执行方式,如全表扫描还是索引扫描,归并连接还是哈希连接等.执行计划可以为用户进行 SQL 调优提供重要依据. DRDS 执行计划 与多数数据库…
这里,我学到的一个很重要的东西,就是用PL/SQL DEVELOPER去看一条SELECT语句的执行计划,执行计划里面可以看到这条SELECT语句的开销.I/O操作开销等数值,可以很清晰地看到语句各个部分的执行效率.选中这条SELECT语句以后,按F5就可以. 以下面的SELECT语句为例子: 从三张表中取数据,按我以前的想法,只要WHERE语句那里有能让三张表连接起来的条件就可以.所以我只使用了: 按F5后,可以看到这样做的执行计划如下: 开销974,其实并不算高.但是加上测试环境的数据库连接…