本文共 2734 字,大约阅读时间需要 9 分钟。
按照OracleOnlineBook中的描述,v$sesstat存储session从login到logout的详细资源使用统计。 类似于v$sysstat,该视图存储下列类别的统计: l 事件发生次数的统计,如用户提交数。 l 数据产生,存取或者操作的total列(如:redo size) l 执行操作所花费的时间累积,例如session CPU占用(如果TIMED_STATISTICS值为true) 注意: 如果初始参数STATISTICS_LEVEL被设置为TYPICAL或ALL,时间统计被数据库自动收集如果STATISTICS_LEVEL被设置为BASIC,你必须设置TIMED_STATISTICS值为TRUE以打开收集功能。 如果你已设置了DB_CACHE_ADVICE,TIMED_STATISTICS或TIMED_OS_STATISTICS,或在初始参数文件或使用ALTER_SYSTEM或ALTER SESSION,那么你所设定的值的值将覆盖STATISTICS_LEVEL的值。 v$sysstat和v$sesstat差别如下: n v$sesstat只保存session数据,而v$sysstat则保存所有sessions的累积值。 n v$sesstat只是暂存数据,session退出后数据即清空。v$sysstat则是累积的,只有当实例被shutdown才会清空。 n v$sesstat不包括统计项名称,如果要获得统计项名称则必须与v$sysstat或v$statname连接查询获得。 v$sesstat可被用于找出如下类型session: n 高资源占用 n 高平均资源占用比(登陆后资源使用率) n 默认资源占用比(两快照之间) 在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常用列说明 n SID:session唯一ID n STATISTIC#:资源唯一ID n VALUE:资源使用 示例1:下列找出当前session中最高的logical和Physical I/O比率. 下列SQL语句显示了所有连接到数据库的session逻辑、物理读比率(每秒)。logical和physical I/O比率是通过自登陆后的时间消耗计算得出。对于sessions连接到数据库这种长周期操作而言也许不够精确,不过做个示例却足够了。 先获得session逻辑读和物理读统计项的STATISTIC#值: SELECTname, statistic# FROM V$STATNAME WHEREnameIN ('session logical reads','physical reads') ; NAME STATISTIC# ------------------------------ ---------- session logical reads 9 physical reads 40 通过上面获得的STATISTIC#值执行下列语句: 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 1965 online 4,879 42.9 19 1668 online 4,318 44.5 1 1142 online 955 69.2 35 1855 batch 573 70.5 8 1971 online 1,138 56.6 1 1323 online 3,263 32.4 5 1479 batch 2,857 35.1 3 421 online 1,322 46.8 15 2405 online 258 50.4 8 示例2:又例如通过v$sesstat和v$statname连接查询某个SID各项信息。 select a.*,b.name from v$sesstat a,v$statname b where a.sid=10and a.statistic#=b.statistic#; (2)-v$mystat 本视图是v$sesstat的一个子集,返回当前session的统计项。当通过触发器审计session资源使用,可以使用v$mystat来捕获资源使用,这将比直接扫描v$sesstat的列要节省资源的多。 转载地址:http://zrwxi.baihongyu.com/