学习动态性能表

第二篇--v$sesstat 

  按照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#;

转载于:https://www.cnblogs.com/jimeper/archive/2008/03/30/1129432.html

学习动态性能表 第二篇--v$sesstat相关推荐

  1. 学习动态性能表 第五篇--V$SESSION

    学习动态性能表 第五篇--V$SESSION  在本视图中,每一个连接到数据库实例中的session都拥有一条记录.包括用户session及后台进程如DBWR,LGWR,arcchiver等等. V$ ...

  2. 学习动态性能表(3)--v$sqlv$sql_plan

    学习动态性能表 第三篇-(1)-v$sq 2007.5.25 V$SQL中存储具体的SQL语句. 一条语句可以映射多个cursor,因为对象所指的cursor可以有不同用户(如例1).如果有多个cur ...

  3. 学习动态性能表(20)--v$waitstat

    学习动态性能表 第20篇--V$WAITSTAT  2007.6.15 本视图保持自实例启动所有的等待事件统计信息.常用于当你发现系统存在大量的"buffer busy waits" ...

  4. 学习动态性能表(10)--v$session_longops

    学习动态性能表 第十篇--V$SESSION_LONGOPS  2007.6.7 本视图显示运行超过6秒的操作的状态.包括备份,恢复,统计信息收集,查询等等. 要监控查询执行进展状况,你必须使用cos ...

  5. 学习动态性能表(19)--v$undostat

    学习动态性能表 第19篇--V$UNDOSTAT  2007.6.14 本视图监控当前实例中undo空间以及事务如何运行.并统计undo空间开销,事务开销以及实例可用的查询长度. V$UNDOSTAT ...

  6. oracle表是动态表怎么算排名,Oracle学习动态性能表

    按照OracleDocument中的描述,v$sysstat存储自数据库实例运行那刻起就开始累计全实例(instance-wide)的资源使用情况. 类似于v$s Oracle 学习动态性能表 v$l ...

  7. juns java,学习动态性能表第六篇-(1)-V$SESSION_WAIT 转自三思 http://junsansi.itpub.net/post/29894/292373...

    这是一个寻找性能瓶颈的关键视图.它提供了任何情况下session在数据库中当前正在等待什么(如果session当前什么也没在做,则显示它最后的等待事件).当系统存在性能问题时,本视图可以做为一个起点指 ...

  8. 分享-动态性能表详解

    从IT-PUB上down下来的一些关于oracle的动态性能表的总结,在大家对oracle进行性能调整和瓶颈检查会有很大的帮助的,不是我写的,在此拿出来跟博客园的朋友分享,共同进步!       一个 ...

  9. DBA必知的170张Oracle常用动态性能表介绍

     DBA必知的170张Oracle常用动态性能表介绍 常用动态性能表.pdf 附录C 动态性能(V$)视图 本附录介绍动态性能视图.这些视图一般作为V$视图引用.本附录包括下列内容: ???? 动态性 ...

最新文章

  1. 微软某员工后悔跳槽阿里:工资才多20万不到,天天加班快崩溃!
  2. A__Java为数据结构提供的实用包的运用(减少代码量)---更新中ing
  3. VTK:PolyData之ExtractSelectedIds
  4. 让您的Eclipse具有千变万化的外观 1
  5. 编程挑战:字符串的完美度
  6. Spring MVC –使用@ResponseBody轻松实现基于REST的JSON服务
  7. 比特币钱包私钥_如何通过私钥创建比特币钱包地址
  8. android.mk添加静态库,Android Gradle添加静态库
  9. MTK 驱动 (70)---MTK Projiectconfig.mk文件详细解释
  10. codevs 5965 [SDOI2017]新生舞会
  11. ifs 报表开发手册_店长工作手册:连锁总部店长复制手册之店长手册对门店经营管理的编写...
  12. React-flux杂记
  13. Windows安装MySql时出现“Failed to find valid data directory”的错误
  14. 河北计算机应用对口升学,2019年河北省中等职业学校对口升学考试:计算机文化基础+计算机应用基础模拟试卷...
  15. 个人游戏开发者是如何盈利
  16. 计算机共享打印怎么设置密码,共享打印机需要密码的解决方法
  17. 16条时间管理法则 让你快速提高效率
  18. 坚果手机2系统相册问题
  19. php 导出excel (html),php两种导出excel的方法
  20. LocalSend 电脑和手机互传软件教程解答手机端无法搜索到电脑的解决方案

热门文章

  1. kodi教程_KODI清理缓存插件安装设置教程
  2. python argparse库_python标准库之argparse
  3. java inputstream的read一次只能读到一个字节_20210118-JAVA面试题
  4. C++知识点39——运算符的重载概念与分数类实现(上)
  5. picACG本地缓存目录_7天用Go动手写/从零实现分布式缓存GeeCache
  6. python面试题之“该死的for循环系列”(二)
  7. live555点播服务器流程深入分析(一)
  8. javascript跳跃式前进(3) - 跳入JSON
  9. 《树莓派Python编程入门与实战(第2版)》——3.9 小结
  10. 创建第二个 local network - 每天5分钟玩转 OpenStack(84)