暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

v$sqlarea

wzf0072 2025-03-07
29

v$sqlarea

本视图持续跟踪所有shared pool中的共享cursor,在shared pool中的每一条SQL语句都对应一列。本视图在分析SQL语句资源使用方面非常重要。

V$SQLAREA中的信息列

  HASH_VALUE:SQL语句的Hash值。

  ADDRESS:SQL语句在SGA中的地址。

这两列被用于鉴别SQL语句,有时,两条不同的语句可能hash值相同。这时候,必须连同ADDRESS一同使用来确认SQL语句。

  PARSING_USER_ID:为语句解析第一条CURSOR的用户

  VERSION_COUNT:语句cursor的数量

  KEPT_VERSIONS:

  SHARABLE_MEMORY:cursor使用的共享内存总数

  PERSISTENT_MEMORY:cursor使用的常驻内存总数

  RUNTIME_MEMORY:cursor使用的运行时内存总数。

  SQL_TEXT:SQL语句的文本(最大只能保存该语句的前1000个字符)。

  MODULE,ACTION:使用了DBMS_APPLICATION_INFO时session解析第一条cursor时的信息

V$SQLAREA中的其它常用列

  SORTS: 语句的排序数

  CPU_TIME: 语句被解析和执行的CPU时间

  ELAPSED_TIME: 语句被解析和执行的共用时间

  PARSE_CALLS: 语句的解析调用(软、硬)次数

  EXECUTIONS: 语句的执行次数

  INVALIDATIONS: 语句的cursor失效次数

  LOADS: 语句载入(载出)数量

  ROWS_PROCESSED: 语句返回的列总数

V$SQLAREA中的连接列

Column   View       Joined Column(s)

HASH_VALUE, ADDRESS V$SESSION SQL_HASH_VALUE, SQL_ADDRESS

HASH_VALUE, ADDRESS V$SQLTEXT, V$SQL, V$OPEN_CURSOR HASH_VALUE, ADDRESS

SQL_TEXT V$DB_OBJECT_CACHE NAME

示例:

 
1.查看消耗资源最多的SQL:
SELECT hash_value, executions, buffer_gets, disk_reads, parse_calls
  FROM V$SQLAREA
 WHERE buffer_gets > 10000000 OR disk_reads > 1000000
 ORDER BY buffer_gets + 100 * disk_reads DESC;
2.查看某条SQL语句的资源消耗:
 SELECT hash_value, buffer_gets, disk_reads, executions, parse_calls,SQL_TEXT
  FROM V$SQLAREA
 WHERE hash_Value = 1906432423 AND address = hextoraw('000000011564D538');
3 查看当前系统的最多消耗
 SELECT osuser, a.username,cpu_time/executions/1000000||'s',executions,b.sql_text,machine   
from v$session a, v$sqlarea b  
where a.sql_address =b.address order by cpu_time/executions desc; 

select *
from (select v.sql_id,
v.child_number,
v.sql_text,
v.elapsed_time,
v.cpu_time,
v.disk_reads,
rank() over(order by v.elapsed_time desc) elapsed_rank
from v$sql v) a
where elapsed_rank <= 10;

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论