学习动态性能表 第十篇--V$SESSION_LONGOPS

 

学习动态性能表

第十篇--V$SESSION_LONGOPS 

本视图显示运行超过6秒的操作的状态。包括备份,恢复,统计信息收集,查询等等。

要监控查询执行进展状况,你必须使用cost-based优化方式,并且:

l         设置TIMED_STATISTICS或SQL_TRACE参数值为true。

l         通过ANALYZE或DBMS_STATS数据包收集对象统计信息。

你可以通过DBMS_APPLICATION_INFO.SET_SESSION_LONGOPS过程添加application-specific长运行操作信息到本视图。关于DBMS_APPLICATION_INFO.SET_SESSION_LONGOPS的更多信息可以浏览:Oracle Supplied PL/SQL Packages and Types Reference。

V$SESSION_LONGOPS列说明

 

l         SID:Session标识

l         SERIAL#:Session串号

l         OPNAME:操作简要说明

l         TARGET:操作运行所在的对象

l         TARGET_DESC:目标对象说明

l         SOFAR:至今为止完成的工作量

l         TOTALWORK:总工作量

l         UNITS:工作量单位

l         START_TIME:操作开始时间

l         LAST_UPDATE_TIME:统计项最后更新时间

l         TIME_REMAINING:预计完成操作的剩余时间(秒)

l         ELAPSED_SECONDS:从操作开始总花费时间(秒)

l         CONTEXT:前后关系

l         MESSAGE:统计项的完整描述

l         USERNAME:执行操作的用户ID

l         SQL_ADDRESS:用于连接查询的列

l         SQL_HASH_VALUE:用于连接查询的列

l         QCSID:

示例:

找一较大表,确认该表查询将超过6秒,哎呀让它快咱没把握,让它慢这可是我的强项啊~~

SQL> set timing on

SQL> create table ttt as select level lv,rownum rn from dual connect by level<10000000;   --创建一个临时表

Table created

Executed in 19.5 seconds

SQL> commit;

Commit complete

Executed in 0 seconds

SQL> select * from (select * from ttt order by lv desc) where rownum<2;    --执行一个费时的查询

 

        LV         RN

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

   9999999    9999999

Executed in 9.766 seconds   --哈哈,成功超过6秒

SQL> select sid,opname,sofar,totalwork,units,sql_hash_value from v$session_longops;      ----看看v$session_longops中是不是已经有记录了

 

       SID OPNAME                                                                SOFAR TOTALWORK UNITS                            SQL_HASH_VALUE

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

        10 Table Scan                                                            47276      47276 Blocks                               2583310173

Executed in 0.047 seconds

 

SQL> select a.sql_text from v$sqlarea a,v$session_longops b where a.HASH_VALUE=b.SQL_HASH_VALUE;   --通过hash_value联系查询出刚执行的查询语句。

 

SQL_TEXT

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

 select * from (select * from ttt order by lv desc) where rownum<2

Executed in 0.063 seconds

时间: 2024-09-21 16:41:11

学习动态性能表 第十篇--V$SESSION_LONGOPS的相关文章

学习动态性能表 第二十篇--V$WAITSTAT

  学习动态性能表 第20篇--V$WAITSTAT  本视图保持自实例启动所有的等待事件统计信息.常用于当你发现系统存在大量的"buffer busy waits"时据此做出适当调整. V$WAITSTAT中的常用列 l         CLASS:块类别 l         WAITS:本类块的等待次数 l         TIME:本类块的总等待时间 等待发生的原因: 1.undo段头部:没有足够的回滚段 2.数据段头部/数据段空闲列:空闲列争夺 3.数据块冲突 4.缓存存在大量

学习动态性能表 第十八篇--V$SYSTEM_EVENT

  学习动态性能表 第18篇--V$SYSTEM_EVENT  本视图概括了实例各项事件的等待信息.v$session_wait显示了系统的当前等待项,v$system_event则提供了自实例启动后各个等待事件的概括.常用于获取系统等待信息的历史影象.而通过两个snapshot获取等待项增量,则可以确定这段时间内系统的等待项. V$SYSTEM_EVENT中的常用列 l         EVENT:等待事件名称 l         TOTAL_WAITS:此项事件总等待次数 l        

学习动态性能表 第十五篇--V$ROLLSTAT

  学习动态性能表 第15篇--V$ROLLSTAT  本视图自启动即保持并记录各回滚段统计项.在学习本视图之前,我们先来了解一下回滚段(rollback segment)的相关概念: 回滚段概述 回滚段用于存放数据修改之前的值(包括数据修改之前的位置和值).回滚段的头部包含正在使用的该回滚段事务的信息.一个事务只能使用一个回滚段来存放它的回滚信息,而一个回滚段可以存放多个事务的回滚信息. 回滚段的作用 1.事务回滚:当事务修改表中数据的时候,该数据修改前的值(即前影像)会存放在回滚段中,当用户

学习动态性能表 第十九篇--V$UNDOSTAT

  学习动态性能表 第19篇--V$UNDOSTAT  本视图监控当前实例中undo空间以及事务如何运行.并统计undo空间开销,事务开销以及实例可用的查询长度. V$UNDOSTAT中的常用列 l         Endtime:以10分钟为间隔的结束时间 l         UndoBlocksUsed:使用的undo块总数 l         TxnConcurrency:事务并发执行的最大数 l         TxnTotal:在时间段内事务执行总数 l         QueryLe

学习动态性能表 第十六篇--V$ROWCACHE

  学习动态性能表 第16篇--V$ROWCACHE  本视图显示数据字典缓存(也叫rowcache)的各项统计.每一条记录包含不同类型的数据字典缓存数据统计,注意数据字典缓存有层次差别,因此同样的缓存名称可能不止一次出现. V$ROWCACHE常用列 l         PARAMETER:缓存名 l         COUNT:缓存项总数 l         USAGE:包含有效数据的缓存项数 l         GETS:请求总数 l         GETMISSES:请求失败数 l  

学习动态性能表 第十四篇--V$PARAMETER&amp;V$SYSTEM_PARAMETER

  学习动态性能表 第14篇--V$PARAMETER&V$SYSTEM_PARAMETER  这两个视图列出的各参数项名称以及参数值.V$PARAMETER显示执行查询的session的参数值.V$SYSTEM_PARAMETER视图则列出实例的参数值. 例如,下列查询显示执行查询的session的SORT_AREA_SIZE参数值: SELECTvalue  FROM V$PARAMETER  WHEREname = 'sort_area_size'; 呵呵,可能有朋友还是不明白v$para

学习动态性能表 第十二篇--V$DB_OBJECT_CACHE

  学习动态性能表 第12篇--V$DB_OBJECT_CACHE  本视图提供对象在library cache(shared pool)中对象统计,提供比v$librarycache更多的细节,并且常用于找出shared pool中的活动对象. v$db_object_cache中的常用列: l         OWNER:对象拥有者 l         NAME:对象名称 l         TYPE:对象类型(如,sequence,procedure,function,package,pa

学习动态性能表 第七篇--V$PROCESS

  学习动态性能表 第七篇--V$PROCESS  本视图包含当前系统oracle运行的所有进程信息.常被用于将oracle或服务进程的操作系统进程ID与数据库session之间建立联系.在某些情况下非常有用: 1.         如果数据库瓶颈是系统资源(如:cpu,内存),并且占用资源最多的用户总是停留在某几个服务进程,那么进行如下诸项: l         找出资源进程 l         找出它们的session,你必须将进程与会话联系起来. l         找出为什么sessio

学习动态性能表 第六篇-(1)-V$SESSION_WAIT

  学习动态性能表 第六篇-(1)-V$SESSION_WAIT  这是一个寻找性能瓶颈的关键视图.它提供了任何情况下session在数据库中当前正在等待什么(如果session当前什么也没在做,则显示它最后的等待事件).当系统存在性能问题时,本视图可以做为一个起点指明探寻问题的方向. V$SESSION_WAIT中,每一个连接到实例的session都对应一条记录. V$SESSION_WAIT中的常用列   l         SID: session标识 l         EVENT: s