我是靠谱客的博主 无语季节,最近开发中收集的这篇文章主要介绍v$session和v$process,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

v$session
 
SADDR: session address
 
SID: session identifier,常用于连接其它列。
 
SERIAL#: sid 会重用,但是同一个sid被重用时,serial#会增加,不会重复。
 
AUDSID: audit session id。可以通过audsid查询当前session的sid。select sid from v$session where audsid=userenv('sessionid');
 
PADDR: process address,关联v$process的addr字段,可以通过这个字段查处当前session对应操作系统的那个进程的id。
 
USER#: session's user id。等于dba_users中的user_id。Oracle内部进程的user#为0。
 
USERNAME: session's username。等于dba_users中的username。Oracle内部进程的username为空。
 
COMMAND: session正在执行的SQL Id。1代表create table,3代表select。
 
TADDR: 当前的transaction address。可以用来关联v$transaction的addr字段。
 
LOCKWAIT: 可以通过这个字段查询出当前正在等待的锁的相关信息。sid & lockwait与v$lock中的sid & kaddr相对应。
 
STATUS: 用来判断session状态。Active:正执行SQL语句。Inactive:等待操作。Killed:被标注为删除。
 
SERVER: server type (dedicated or shared)
 
SCHEMA#: schema user id。Oracle内部进程的schema#为0。
 
SCHEMANAME: schema username。Oracle内部进程的schemaname为sys。
 
OSUSER: 客户端操作系统用户名。
 
PROCESS: 客户端process id。
 
MACHINE: 客户端machine name。
 
TERMINAL: 客户端执行的terminal name。
 
PROGRAM: 客户端应用程序。比如ORACLE.EXE (PMON)或者sqlplus.exe
 
TYPE: session type (background or user)

blocking_session: 阻塞本session的sessionID
 
SQL_ADDRESS, SQL_HASH_VALUE, SQL_ID, SQL_CHILD_NUMBER: session正在执行的sql statement,和v$sql中的address, hash_value, sql_id, child_number相对应。
 
PREV_SQL_ADDR, PREV_HASH_VALUE, PREV_SQL_ID, PREV_CHILD_NUMBER: 上一次执行的sql statement。
 
MODULE, MODULE_HASH, ACTION, ACTION_HASH, CLIENT_INFO: 应用通过DBMS_APPLICATION_INFO设置的一些信息。
 
FIXED_TABLE_SEQUENCE: 当session完成一个user call后就会增加的一个数值,也就是说,如果session inactive,它就不会增加。因此可以根据此字段的值变化来监控某个时间点以来的session的性能情况。例如,一个小时以前,某个session的FIXED_TABLE_SEQUENCE是10000,而现在是20000,则表明一个小时内其user call比较频繁,可以重点关注此session的performance statistics。
 
ROW_WAIT_OBJ#: 被锁定行所在table的object_id。和dba_objects中的object_id关联可以得到被锁定的table name。
 
ROW_WAIT_FILE#: 被锁定行所在的datafile id。和v$datafile中的file#关联可以得到datafile name。
 
ROW_WAIT_BLOCK#: Identifier for the block containing the row specified in ROW_WAIT_ROW#
 
ROW_WAIT_ROW#: session当前正在等待的被锁定的行。
 
LOGON_TIME: session logon time

查看当前用户的sid和serial#:

点击(此处)折叠或打开

  1. select sid, serial#, status from v$session where audsid=userenv('sessionid');
知道了sid,就可以知道当前正在执行的sql语句:
select t.piece,t.sql_text from v$session s,v$sqltext t where s.sql_id = t.sql_id and s.sid = :sid order by t.piece;

点击(此处)折叠或打开

  1. select sid, serial#, status from v$session where audsid=userenv('sessionid');
道了sid,就可以知道当前正在执行的sql语句:

点击(此处)折叠或打开

select t.piece,t.sql_text from v$session s,v$sqltext t where s.sql_id = t.sql_id and s.sid = :sid order by t.piece;
select t.piece,t.sql_text from v$session s,v$sqltext t where s.SQL_ADDRESS = t.ADDRESS and s.sid =:SID order by t.piece;
select t.piece,t.sql_text from v$session s,v$sqltext t where s.SQL_HASH_VALUE = t.HASH_VALUE and s.sid = :SID order by t.piece;
通过V$SESSION 和v$lock查看锁定信息:

点击(此处)折叠或打开

select username,
       v$lock.sid,
       trunc(id1 / power(2, 16)) rbs,
       bitand(id1, to_number('ffff', 'xxxx')) + 0 slot,
       id2 seq,
       lmode,
       request
  from v$lock, v$session
 where v$lock.type = 'TX'
   and v$lock.sid = v$session.sid
   and v$session.username = USER;
USERNAME SID RBS SLOT SEQ
------------------------------ ---------- ---------- ---------- ----------
LMODE REQUEST
---------- ----------
MOBILE_V2 773 12 76 13925
         6 0

MOBILE_V2 1163 16 81 13868
         6 0
$LOCK 表中的LMODE为6,REQUEST 为0。如果在Oracle Server Reference 手册中查看V$LOCK
表的定义,会发现LMODE=6 是一个排他锁。请求(REQUEST)值为0 则意味着你没有发出请求;
也就是说,你拥有这个锁。

v$process

 
ADDR: process address。可以和v$session的paddr字段关联。
 
PID: Oracle进程identifier。
 
SPID: 操作系统进程identifier。
 
USERNAME: 操作系统进程的用户名。并非Oracle用户名。
 
SERIAL#: process serial number。
 
TERMINAL: 操作系统terminal identifier(e.g., computer name)。
 
PROGRAM: 进程正在执行的程序(e.g., ORACLE.EXE (ARC0)),和v$session中的program类似。
 
BACKGROUND: 1代表oracle background process,null代表normal process。

查看当前用户的trace file路径:

点击(此处)折叠或打开

  1. select c.value || '/' || d.instance_name || '_ora_' || a.spid || '.trc' trace
  2.   from v$process a, v$session b, v$parameter c, v$instance d
  3.  where a.addr = b.paddr
  4.    and b.audsid = userenv('sessionid')
  5.    and c.name = 'user_dump_dest'





来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/24107336/viewspace-1183042/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/24107336/viewspace-1183042/

最后

以上就是无语季节为你收集整理的v$session和v$process的全部内容,希望文章能够帮你解决v$session和v$process所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(38)

评论列表共有 0 条评论

立即
投稿
返回
顶部