通过Oracle动态性能视图采集查询调优数

对于现在的一些发行版本,DBA(Database Administrator,数据库管理员)和开发员可以访问的已经有三种动态性能视图了,分别为V$SQL、V$SQLAREA,还有V$SQLTEXT。

这些视图可以用来采集有关SQL命令执行的统计信息。在Oracle 10g, Release 2中,还增加了第四个动态性能视图,V$SQLSTATS,通过它能更方便地访问这类数据。

和静态数据字典视图(static dictionary view,也就是前缀为USER_、ALL_,或者DBA_的视图)不同,动态性能视图会随着系统的运行而不断更新。这使得有可能在SQL语句执行之时监视其性能。

和静态视图一样的是,要使用它们你要先获得许可。对于非数据库管理员用户(如典型的开发环境下)可赋予SELECT_CATALOG_ROLE权限,让他们可以从中选择它们。

下面是各个视图所提供功能的一些简要描述。要获得更多信息,请参考Oracle Database 10g 指南, 第7章。

  • V$SQL:这个视图使用一个CLOB(character large object,字符型巨对象)column(栏,也就是视图中的属性字段),以提供SQL语句的完整文本,此外还有一列最多存放1000个VARCHAR2字符(存放SQL语句的前1000个字符)的对象,这方便了使用。可访问的统计数据相当广泛:包括解析语句(parse)和非法语句的数目、磁盘的读写次数、运行时间、等待时间,还有optimizer(优化器)数据。你还可以从中知道创建语句的用户和schema(部署对象),以及当前有多少用户正在执行它。
  • V$SQLAREA:这个视图包含许多和V$SQL相同的统计信息。可是,V$SQL对每条初始SQL语句及其子语句(child)都要包含一行统计信息,而这个视图只对实际输入的SQL字串产生一条统计信息。
  • V$SQLSTATS:这是10gR2版中新加入的视图,这个视图比V$SQL和V$SQLAREA更快更方便,它只包含其它视图column的子集。一般来说,它不连接用户信息。它的每一行对应一条SQL语句及其执行计划的hash value(杂凑值)。它的额外的优点是,这个视图中的纪录入口比其它视图更为持久。因此,虽然某一条语句已经在共享池中过期失效(这导致它从V$SQLAREA中消失),但你仍然可以通过该视图找到它。
  • V$SQLTEXT:有时候你会想得到分开的每一行SQL语句,而不是V$SQL中给出的一个巨对象;那么V$SQL可以让你如愿。你可以通过COMMAND_TYPE栏中的代号选择特定的某种类型的语句(比如,选择INSERT语句,或者SELECT语句)。SQL_TEXT column中存放的是单个语句,而PIECE column则给语句编上号码,以便通过 ORDER BY来排序。另外有一个叫V$SQLTEXT_WITH_NELINES的变量会保留原来的换行符以改善可读性(V$SQLTEXT会用空格替代换行符)。V$SQLTEXT和V$SQLTEXT_WITH_NEWLINES都不会告诉你是谁执行了这条语句,或者是谁在提供给你这些统计信息。如果要获得那类信息,你还得通过V$SQL和V$SQLAREA视图中的ADDRESS和HASH_VALUE column实现。

这四个视图工具合到一起,共同为你提供了原始资料,帮助你检测你的SQL数据库执行状况如何。

Bob Watkins(OCP,MCDBA,MCSE,MCT)作为计算机专家,有着25年做技术培训师、顾问,以及数据库管理员的经验。

时间: 2024-08-02 23:31:44

通过Oracle动态性能视图采集查询调优数的相关文章

Oracle给普通用户赋予查询动态性能视图的权限

给普通用户赋予查询动态性能视图的权限时,动态性能视图的名字不能像是平常那种写法V$,而是应写成V_$:

详解Oracle常用的动态性能视图

首先看看什么时候使用动态性能视图: (1)NOMOUNT 启动例程时,Oracle会打开参数文件,分配SGA并启动后台进程.因此,当例程处于NOMOUNT状态时,只能访问访问从SGA 中获取信息的动态性能视图. (2)MOUNT 装在数据库时,Oracle根据初始化参数control_files打开所有的控制文件.当例程处于mount状态时,不仅可以访问从SGA中获取信息的动态性能视图,还可以访问从控制文件中获取信息的动态性能视图. (3)OPEN 只有处于OPEN状态时,才能访问数据字典视图.

Oracle 常用性能视图一览表(10g)

--*************************************-- Oracle 常用性能视图一览表(10g)--************************************* Advisors     Information related to cache advisors v$pga_target_advice v$shared_pool_advice v$pga_target_advice_histogram v$java_pool_advice v$mttr

oracle最重要的9个动态性能视图

v$session + v$session_wait (在10g里功能被整合,凑合算1个吧.) v$process v$sql v$sqltext v$bh (更宁愿是x$bh) v$lock v$latch_children v$sysstat v$system_event 按组分的几组重要的性能视图 1.System 的 over view v$sysstat , v$system_event , v$parameter 2.某个session 的当前情况 v$process , v$ses

Oracle权限(二)权限相关的动态性能视图与数据字典视图

001 DBA_USERS DBA_USERS 描述了数据库中所有的用户信息. 相关视图: USER_USERS 描述了当前用户的信息.该视图不包括 PASSWORD, PROFILE, PASSWORD_VERSIONS, EDITIONS_ENABLED, 和AUTHENTICATION_TYPE 列. Column Description USERNAME 用户名 USER_ID 用户ID PASSWORD 为了支持AUTHENTICATION_TYPE 列,该列已被弃用 ACCOUNT_

提高商业智能环境中DB2查询的性能-专用于数据仓库和B 的查询调优方法(2)

方法 1:在事实表与三个维度表之间定义适当的参照完整性约束 在 DB2 中,可以定义主键和外键约束,以允许数据库管理器对数据实施参照完整性约束.外键等参照约束还有助于提高性能.例如,如果修改 清单 2 中的查询中的子表达式 TMP1,去掉 PRODUCT_DIM 表上的本地谓词,那么,如果在 SALES_FACT.PRODUCT_ID 上创建一个外键约束,则优化器会消除 SALES_FACT 和 PRODUCT_DIM 之间的连接.如果创建了外键约束,则那样的连接被认为是无损的(lossless

OCP1z0-047 :基本概念:同义词、动态性能视图、数据字典视图

答案A是对的,来自己官方的解释: USER_SYNONYMS USER_SYNONYMS describes theprivate synonyms (synonyms owned by the current user). Its columns () are thesame as those in ALL_SYNONYMS. 测试如下:创建两个同义词:一个是公共的,一个是私有的,然后再查询 gyj@OCM> createsynonym emp1 for hr.employees; Synon

Mysql 查询调优记录

http://blog.csdn.net/xtdhqdhq/article/details/20377273 Using index:表示使用索引,如果只有 Using index,说明他没有查询到数据表,只用索引表就完成了这个查询,这个叫覆盖索引.如果同时出现Using where,代表使用索引来查找读取记录, 也是可以用到索引的,但是需要查询到数据表. Using where:表示条件查询,如果不读取表的所有数据,或不是仅仅通过索引就可以获取所有需要的数据,则会出现 Using where.

Oracle 10g的常用性能视图

--************************************* -- Oracle 常用性能视图一览表(10g) --************************************* Advisors Information related to cache advisors v$pga_target_advice v$shared_pool_advice v$pga_target_advice_histogram v$java_pool_advice v$mttr_t