Oracle视图--v$sesstat

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Oracle视图--v$sesstat 2007.5.25

按照OracleOnlineBook中的描述,v$sesstat存储session从login到logout的详细资源使用统计。

类似于v$sysstat,该视图存储下列类别的统计:

●事件发生次数的统计,如用户提交数。

●数据产生,存取或者操作的total列(如:redo size)

●执行操作所花费的时间累积,例如session CPU占用(如果TIMED_STATISTICS值

为true)

注意:

如果初始参数STATISTICS_LEVEL被设置为TYPICAL或ALL,时间统计被数据库自动收集如果STA TISTICS_LEVEL被设置为BASIC,你必须设置TIMED_STATISTICS 值为TRUE以打开收集功能。

如果你已设置了DB_CACHE_ADVICE,TIMED_STATISTICS或TIMED_OS_STA TISTICS,或在初始参数文件或使用ALTER_SYSTEM或ALTER SESSION,那么你所设定的值的值将覆盖STA TISTICS_LEVEL的值。

v$sysstat和v$sesstat差别如下:

⏹v$sesstat只保存session数据,而v$sysstat则保存所有sessions的累积值。

⏹v$sesstat只是暂存数据,session退出后数据即清空。v$sysstat则是累积的,只有当

实例被shutdown才会清空。

⏹v$sesstat不包括统计项名称,如果要获得统计项名称则必须与v$sysstat或

v$statname连接查询获得。

v$sesstat可被用于找出如下类型session:

⏹高资源占用

⏹高平均资源占用比(登陆后资源使用率)

⏹默认资源占用比(两快照之间)

在V$SESSTAT中使用统计

多数v$sesstat中的统计参考是v$sysstat描述的子集,包括session logical reads, CPU used by this session, db block changes, redo size, physical writes, parse count (hard), parse count (total), sorts (memory), and sorts (disk).

V$SESSTAT常用列说明

⏹SID:session唯一ID

⏹STATISTIC#:资源唯一ID

⏹V ALUE:资源使用

示例1:下列找出当前session中最高的logical和Physical I/O比率.

下列SQL语句显示了所有连接到数据库的session逻辑、物理读比率(每秒)。logical和physical I/O比率是通过自登陆后的时间消耗计算得出。对于sessions连接到数据库这种长周期操作而言也许不够精确,不过做个示例却足够了。

先获得session逻辑读和物理读统计项的STA TISTIC#值:

SELECT name, statistic#

FROM V$STATNAME

WHERE name IN ('session logical reads','physical reads') ;

NAME STATISTIC#

------------------------------ ----------

session logical reads 9

physical reads 40

通过上面获得的STA TISTIC#值执行下列语句:

SELECT ses.sid

, DECODE(ses.action,NULL,'online','batch') "User"

, MAX(DECODE(sta.statistic#,9,sta.value,0))

/greatest(3600*24*(sysdate-ses.logon_time),1) "Log IO/s"

, MAX(DECODE(sta.statistic#,40,sta.value,0))

/greatest(3600*24*(sysdate-ses.logon_time),1) "Phy IO/s"

, 60*24*(sysdate-ses.logon_time) "Minutes"

FROM V$SESSION ses

, V$SESSTAT sta

WHERE ses.status = 'ACTIVE'

AND sta.sid = ses.sid

AND sta.statistic# IN (9,40)

GROUP BY ses.sid, ses.action, ses.logon_time

ORDER BY

SUM( DECODE(sta.statistic#,40,100*sta.value,sta.value) )

/ greatest(3600*24*(sysdate-ses.logon_time),1) DESC;

SID User Log IO/s Phy IO/s Minutes

----- ------ -------- -------- -------

1951 batch 291 257.3 1

470 online 6,161 62.9 0

730 batch 7,568 43.2 197

2153 online 1,482 98.9 10

2386 batch 7,620 35.6 35

1815 batch 7,503 35.5 26

相关文档
最新文档