`

学习动态性能表(三)-(2)-V$SQL_PLAN

阅读更多

本视图提供了一种方式检查那些执行过的并且仍在缓存中的cursor的执行计划。
  通常,本视图提供的信息与打印出的EXPLAIN PLAN非常相似,不过,EXPLAIN PLAN显示的是理论上的计划,并不一定在执行的时候就会被使用,但V$SQL_PLAN中包括的是实际被使用的计划。获自EXPLAIN PLAN语句的执行计划跟具体执行的计划可以不同,因为cursor可能被不同的session参数值编译(如,HASH_AREA_SIZE)。

V$SQL_PLAN中数据可以:  确认当前的执行计划
  鉴别创建表索引效果
  寻找cursor包括的存取路径(例如,全表查询或范围索引查询)
  鉴别索引的选择是否最优
  决定是否最优化选择的详细执行计划(如,nested loops join)如开发者所愿。

  本视图同时也可被用于当成一种关键机制在计划对比中。计划对比通常用于下列各项发生改变时:

  删除和新建索引
  在数据库对象上执行分析语句
  修改初始参数值
  从rule-based切换至cost-based优化方式
  升级应用程序或数据库到新版本之后

  如果之前的计划仍然在(例如,从V$SQL_PLAN选择出记录并保存到Oracle表中供参考),那么就有可能去鉴别一条SQL语句在执行计划改变后性能方面有什么变化。

注意:
Oracle公司强烈推荐你使用DBMS_STATS包而非ANALYZE收集优化统计。该包可以让你平行地搜集统计项,收集分区对象(partitioned objects)的全集统计,并且通过其它方式更好的调整你的统计收集方式。此处,cost-based优化器将最终使用被DBMS_STATS收集的统计项。浏览Oracle9i Supplied PL/SQL包和类型参考以获得关于此包的更多信息。

不过,你必须使用ANALYZE语句而非DBMS_STATS进行统计收集,不涉及cost-based优化器,就像:
·使用VALIDATE或LIST CHAINED ROWS子句
·在freelist blocks上收集信息。

V$SQL_PLAN中的常用列:

除了一些新加列,本视图几乎包括所有的PLAN_TABLE列,那些同样存在于PLAN_TABLE中的列拥有相同的值:
ADDRESS:当前cursor父句柄位置
HASH_VALUE:在library cache中父语句的HASH值。
ADDRESS和HASH_VALUE这两列可以被用于连接v$sqlarea查询 cursor-specific 信息。
CHILD_NUMBER:使用这个执行计划的子cursor数
列ADDRESS,HASH_VALUE以及CHILD_NUMBER可被用于连接v$sql查询子cursor信息。
OPERATION: 在各步骤执行内部操作的名称,例如:TABLE ACCESS
OPTIONS: 描述列OPERATION在操作上的变种,例如:FULL
OBJECT_NODE: 用于访问对象的数据库链接database link 的名称对于使用并行执行的本地查询该列能够描述操作中输出的次序。
OBJECT#: 表或索引对象数量
OBJECT_OWNER: 对于包含有表或索引的架构schema 给出其所有者的名称
OBJECT_NAME: 表或索引名
OPTIMIZER: 执行计划中首列的默认优化模式;例如,CHOOSE。比如业务是个存储数据库,它将告知是否对象是最优化的。
ID: 在执行计划中分派到每一步的序号。
PARENT_ID: 对ID 步骤的输出进行操作的下一个执行步骤的ID。
DEPTH: 业务树深度(或级)。
POSITION: 对于具有相同PARENT_ID 的操作其相应的处理次序。
COST: cost-based方式优化的操作开销的评估,如果语句使用rule-based方式,本列将为空。
CARDINALITY: 根据cost-based方式操作所访问的行数的评估。
BYTES: 根据cost-based方式操作产生的字节的评估,。
OTHER_TAG: 其它列的内容说明。
PARTITION_START: 范围存取分区中的开始分区。
PARTITION_STOP: 范围存取分区中的停止分区。
PARTITION_ID: 计算PARTITION_START和PARTITION_STOP这对列值的步数
OTHER: 其它信息即执行步骤细节,供用户参考。
DISTRIBUTION: 为了并行查询,存储用于从生产服务器到消费服务器分配列的方法
CPU_COST: 根据cost-based方式CPU操作开销的评估。如果语句使用rule-based方式,本列为空。
IO_COST: 根据cost-based方式I/O操作开销的评估。如果语句使用rule-based方式,本列为空。
TEMP_SPACE: cost-based方式操作(sort or hash-join)的临时空间占用评估。如果语句使用rule-based方式,本列为空。
ACCESS_PREDICATES: 指明以便在存取结构中定位列,例如,在范围索引查询中的开始或者结束位置。
FILTER_PREDICATES: 在生成数据之前即指明过滤列。

CONNECT BY操作产生DEPTH列替换LEVEL伪列,有时被用于在SQL脚本中帮助indent PLAN_TABLE数据

V$SQL_PLAN中的连接列
  列ADDRESS,HASH_VALUE和CHILD_NUMBER被用于连接V$SQL或V$SQLAREA来获取cursor-specific信息,例如,BUFFER_GET,或连接V$SQLTEXT获取完整的SQL语句。
Column View Joined Column(s)
ADDRESS, HASH_VALUE V$SQLAREA ADDRESS, HASH_VALUE
ADDRESS,HASH_VALUE,CHILD_NUMBER V$SQL ADDRESS,HASH_VALUE,CHILD_NUMBER
ADDRESS, HASH_VALUE V$SQLTEXT ADDRESS, HASH_VALUE


确认SQL语句的优化计划
  下列语句显示一条指定SQL语句的执行计划。查看一条SQL语句的执行计划是调整优化SQL语句的第一步。这条被查询到执行计划的SQL语句是通过语句的HASH_VALUE和ADDRESS列识别。分两步执行:

1.SELECT sql_text, address, hash_value FROM v$sql
WHERE sql_text like '%TAG%';

SQL_TEXT ADDRESS HASH_VALUE
-------- -------- ----------
82157784 1224822469


2.SELECT operation, options, object_name, cost FROM v$sql_plan
WHERE address = '82157784' AND hash_value = 1224822469;

OPERATION OPTIONS OBJECT_NAME COST
-------------------- ------------- ------------------ ----
SELECT STATEMENT 5
SORT
AGGREGATE
HASH JOIN 5
TABLE ACCESS FULL DEPARTMENTS 2
TABLE ACCESS FULL EMPLOYEES 2

分享到:
评论

相关推荐

    学些动态性能表-word版

    学习动态性能表(三)--v$sql&v$sql_plan 学习动态性能表(四)--v$sqltext&v$sqlarea 学习动态性能表(五)--v$session 学习动态性能表(六)--v$session_wait&v$session_event 学习动态性能表(七)--v$process 学习...

    v$sql_plan[总结].pdf

    如果之前的计划仍然在(例如,从 V$SQL_PLAN 选择出记录并保存到 oracle 表中供参考),那么就有可能去鉴别一条 SQL 语句在执行计划改变后性能方面有什么变化。 v$sql_plan视图中的常用列包括: 1. ADDRESS:当前 ...

    oracle 动态性能视图 (x$, v$, gv$, v_$, gv_$)

    Oracle的动态性能视图主要有X$、V$、V_$和GV$系列,每一系列都有其独特的用途和访问权限。 ### X$ 系列视图 X$系列视图包含了Oracle数据库实例的底层数据结构信息,它们是数据库内核的一部分,由Oracle服务器直接...

    oracle_V$SQLAREA_.rar_oracle_oracle V$sqlarea

    在Oracle数据库系统中,`V$SQLAREA` 是一个非常重要的动态性能视图,它提供了关于解析、编译和执行的SQL语句的详细信息。这个视图是DBA和性能调优专家用来监控和分析SQL性能的关键工具。标题中的"oracle_V$SQLAREA_....

    性能调优分析之:Oracle SQL执行计划报告生成器

    Oracle SQL执行计划分析器...(View Create Script v1.0.sql) 如果出现没权限访问GV$SQL_PLAN_MONITOR这些对象,请先用sys用户赋值。 3 最后,编译XYG_ALD_SESS_PKG的包体。完工! (XYG_ALD_SESS_PKG_BODY.sql)

    sql执行详解

    - `V$SQL_PLAN_STATISTICS_ALL`:结合V$SQL_PLAN和V$SQL_PAN提供执行计划的详细统计信息。 - `V$SQL_OPTIMIZER_ENV`:包含影响CBO的初始化参数。 - `V$SYS_OPTIMIZER_ENV`:影响整个实例的系统参数,其变化可能...

    学习Oracle动态性能表

    2. **v$sql&v$sql_plan**:v$sql视图存储了最近执行的SQL语句及其相关信息,如执行次数、CPU时间等。v$sql_plan则给出了SQL执行的具体执行计划,帮助分析查询性能,优化查询语句。 3. **v$process**:记录了所有...

    Oracle-Perf-check-sql.rar_oracle

    使用EXPLAIN PLAN语句或者DBMS_XPLAN包可以查看SQL的执行路径,分析是否存在全表扫描、索引使用不当等问题。 6. **资源使用情况**:V$INSTANCE和V$PGA Aggregate Views等视图可以展示CPU、内存、I/O等资源的使用...

    oracle性能监控常用语句集合

    例如,`V$SESSION`用于查看当前会话状态,`V$INSTANCE`显示实例信息,`V$SESSION_WAIT`揭示会话等待事件,而`V$SQL`和`V$SQLAREA`则用于分析SQL性能。 2. **系统资源监控**: - `SELECT * FROM V$PGA_MEMORY_...

    SQLyouhua_v1.0.rar_HB-SQLyou_oracle_sql you_sql优化

    《SQL优化手册_v1.0.doc》是一份专门针对Oracle数据库SQL优化的详细指南,旨在帮助用户提升SQL语句的执行效率,进而提高整体数据库系统的性能。在Oracle数据库管理中,SQL优化是至关重要的,因为它直接影响到数据的...

    oracle 动态性能(V$)视图

    4. SQL调优方法,包括如何使用V$SQL视图、EXPLAIN PLAN和ASH(活动会话历史)来分析SQL执行计划和性能。 5. 实例内存管理策略,如自动内存管理(Automatic Memory Management)和手工内存管理的比较和应用。 6. 具体...

    oracle动态链接表

    * V$SQL_PLAN 表提供了 SQL 语句的执行计划信息,包括执行路径、索引使用情况等。 * 该表可以帮助 DBA 了解 SQL 语句的执行计划和优化建议。 5. V$SQLTEXT 表:包括 Shared pool 中 SQL 语句的完整文本。 * V$...

    SQL优化器相关知识 精品资料.pptx

    2. V$SQL_PLAN_STATISTICS视图:提供SQL语句的执行计划统计信息,包括执行计划的详细信息和执行统计信息。 3. V$SQL_PLAN_STATISTICS_ALL视图:提供SQL语句的执行计划统计信息,包括执行计划的详细信息和执行统计...

    定位Oracle中的TOP_SQL

    该值可以与 V$SQL_PLAN 视图结合使用,来找到 TOP_SQL 的执行计划。 ### 方法六:通过打印排序多的 SQL 可以通过打印排序多的 SQL 来找到 TOP_SQL。该方法可以通过 V$SESSION 视图来实现,根据 TABLESPACE 和 ...

    20个常用的动态性能视图

    3. **v$sql & v$sql_plan**:这两个视图组合起来提供了关于执行过的SQL语句及其执行计划的详细信息,对于分析SQL性能、查询效率和优化执行路径非常重要。 4. **v$sqltext & v$sqlarea**:v$sqltext用于获取SQL语句...

    如何监控Oracle索引的使用完全解析

    V$SQL_PLAN视图记录了实际执行的计划,通过ADDRESS和HASH_VALUE列来标识SQL语句,相比Oracle 8i的STATEMENT_ID方法,更便于跟踪动态变化的SQL执行计划。 监控索引使用的一个实例脚本在Oracle 8i中可以这样编写,但...

    Oracle运维最佳实践-下.pdf 带书签

    - 使用`DBMS_WORKLOAD_REPOSITORY`包来查询AWR数据,如`DBMS_WORKLOAD_REPOSITORY.REPORT_SQL_MONITOR`函数可以生成特定SQL语句的性能报告。 - **2.1.2 SPA(SQL Performance Analyzer)** - SPA是一个强大的工具...

    oracle动态性能视图详解

    6. **V$SQL&V$SQL_PLAN**: V$SQL存储了SQL语句的信息,V$SQL_PLAN则包含了执行计划。分析这两者可以帮助我们理解SQL执行的效率和可能的改进点。 7. **V$SESSION**: 和V$SESSION_WAIT一起,这些视图揭示了会话的当前...

    SQL_最实用的学习资料没有之一

    ### SQL 最实用的学习资料知识点详解 #### 一、SQL 语句整理大全 **1. 查看某个回滚段中的事务或SQL语句** - **语法:** ```sql SQL> SELECT D.SQL_TEXT, A.NAME FROM V$ROLLNAME A, V$TRANSACTION B, V$...

    SQL优化器相关知识.pptx

    v$sql_plan、v$sql_plan_statistics以及v$sql_plan_statistics_all提供更多详细的执行计划和统计信息。 优化路径涵盖了多种访问方法,包括ROWID的单行访问、索引扫描、全表扫描、排序合并连接等。分析数据是CBO制定...

Global site tag (gtag.js) - Google Analytics