对于现在的一些发行版本DBA(Database Administrator数据库管理员)和开发员可以访问的已经有三种动态性能视图了分别为V$SQLV$SQLAREA还有V$SQLTEXT
这些视图可以用来采集有关SQL命令执行的统计信息在Oracle g Release 中还增加了第四个动态性能视图V$SQLSTATS通过它能更方便地访问这类数据
和静态数据字典视图(static dictionary view也就是前缀为USER_ALL_或者DBA_的视图)不同动态性能视图会随着系统的运行而不断更新这使得有可能在SQL语句执行之时监视其性能
和静态视图一样的是要使用它们你要先获得许可对于非数据库管理员用户(如典型的开发环境下)可赋予SELECT_CATALOG_ROLE权限让他们可以从中选择它们
下面是各个视图所提供功能的一些简要描述要获得更多信息请参考Oracle Database g 指南 第章
V$SQL:这个视图使用一个CLOB(character large object字符型巨对象)column(栏也就是视图中的属性字段)以提供SQL语句的完整文本此外还有一列最多存放个VARCHAR字符(存放SQL语句的前个字符)的对象这方便了使用可访问的统计数据相当广泛包括解析语句(parse)和非法语句的数目磁盘的读写次数运行时间等待时间还有optimizer(优化器)数据你还可以从中知道创建语句的用户和schema(部署对象)以及当前有多少用户正在执行它
V$SQLAREA:这个视图包含许多和V$SQL相同的统计信息可是V$SQL对每条初始SQL语句及其子语句(child)都要包含一行统计信息而这个视图只对实际输入的SQL字串产生一条统计信息
V$SQLSTATS:这是gR版中新加入的视图这个视图比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(OCPMCDBAMCSEMCT)作为计算机专家有着年做技术培训师顾问以及数据库管理员的经验