如何用Oracle动态视图采集查询调优数

数据库 Oracle
初学者对于Oracle动态性能视图可能会很陌生,这里就简单概述下Oracle动态视图的数据字典。希望能帮上你。

初学者对于Oracle动态视图可能会很陌生,这里就简单概述下Oracle动态性能视图的数据字典。以数据库管理员和开发员身份可以访问Oracle动态视图,分别为V$SQL、V$SQLAREA,还有V$SQLTEXT。

这些视图可以用来采集有关SQL命令执行的统计信息。在Oracle 10g, Release 2 中,还增加了第四个动态性能视图,V$SQLSTATS,通过它能更方便地访问这类数据。和静态数据字典视图(static dictionary view,也就是前缀为USER_、ALL_,或者DBA_的视图)不同,Oracle动态视图会随着系统的运行而不断更新。这使得有可能在SQL语句执行之时监视其性能。

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

下面是各个视图所提供功能的一些简要描述:

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实现。

有效的应用这些Oracle动态视图工具,可以很好的帮助你检测SQL数据库执行状况如何。

【编辑推荐】

  1. 如何用Oracle 9i全索引扫描完成任务
  2. Oracle服务器如何进一步的获取权限
  3. 对Oracle数据库设计中字段的正确使用方案
  4. 访问 Oracle 数据库的实例描述
  5. Oracle数据库的密集型实际应用程序的开发
责任编辑:佚名
相关推荐

2011-05-20 14:23:01

Oracle调优

2011-05-18 10:16:24

Oracle调优

2011-05-20 15:02:01

Oracle性能调优

2009-11-17 13:45:12

Oracle SQL调

2011-05-19 14:11:29

Oracle

2023-11-10 09:25:36

Oracle数据库

2010-04-12 17:30:44

Oracle SQL调

2009-04-01 11:17:52

内存分配调优Oracle

2012-01-10 14:35:08

JavaJVM

2009-11-17 14:50:50

Oracle调优

2017-07-21 08:55:13

TomcatJVM容器

2011-05-24 09:45:41

Oracle数据库系统调优

2009-11-05 10:03:25

Oracle调优NUMA架构

2011-07-13 14:02:42

OracleExcel

2010-04-22 16:39:21

Oracle 调优

2010-05-05 14:04:31

Oracle 性能

2021-03-04 08:39:21

SparkRDD调优

2011-04-18 13:23:46

数据库查询

2019-10-10 17:05:44

华为

2010-05-24 14:24:27

MySQL查询
点赞
收藏

51CTO技术栈公众号