v$process和v$session中字段解释

v$process
这个视图提供的信息,都是oracle服 务进程的信息,没有客户端程序相关的信息
服务进程分两类,一是后台的,一是dedicate/shared server
pid, serial# 这是oracle分配的PID
spid 这才是操作系统的pid
program 这是服务进程对应的操作系统进程名

v$session:
这 个视图主要提供的是一个数据库connect的信息,
主要是client端的信息,比如以下字段:
machine 在哪台机器上
terminal 使用什么终端
osuser 操作系统用户是谁
program 通过什么客户端程序,比如TOAD
process 操作系统分配给TOAD的进程号
logon_time 在什么时间
username 以什么oracle的帐号登录
command 执行了什么类型的SQL命令
sql_hash_value SQL语句信息

有一些是server端的信息:
paddr 即v$process中的server进程的addr
server 服务器是dedicate/shared

还 有其它一些信息,可以理解为是client/server共享的信息,主要是针对这个session而言的
 

v$session

 

SADDR:sessionaddress

 

SID:sessionidentifier, 常用于连接其它列。

 

SERIAL#: sid 会重用,但是同一个sid被重用时,serial#会增加,不会重复。

 

AUDSID: auditsessionid。可以通过audsid查询当前session的sid。 select sid fromv$sessionwhere audsid=userenv('sessionid');

 

PADDR:processaddress, 关联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: 客户端processid。

 

MACHINE: 客户端machine name。

 

TERMINAL: 客户端执行的terminal name。

 

PROGRAM: 客户端应用程序。比如ORACLE.EXE (PMON)或者sqlplus.exe

 

TYPE:sessiontype (background or user)

 

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后就会增加的一个数值,也就是说,如果sessioninactive, 它就不会增加。因此可以根据此字段的值变化来监控某个时间点以来的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:sessionlogon time

 

v$process

 

ADDR:processaddress。 可以和v$session的paddr字 段关联。

 

PID: Oracle进程identifier。

 

SPID: 操作系统进程identifier。

 

USERNAME: 操作系统进程的用户名。并非Oracle用户名。

 

SERIAL#::processserial number。

 

TERMINAL: 操作系统terminal identifier(e.g., computer name)。

 

PROGRAM: 进程正在执行的程序(e.g., ORACLE.EXE (ARC0)),和v$session中 的program类似。

 

BACKGROUND: 1代表oracle backgroundprocess,null代表normalprocess

 

 

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

select sid, serial#, status fromv$sessionwhere audsid=userenv('sessionid');

 

查看当前用户的spid:

select spid fromv$processp,v$sessions where s.audsid=userenv('sessionid') and s.paddr=p.addr;

select spid fromv$processp joinv$sessions on p.addr=s.paddr and s.audsid=userenv('sessionid');

 

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

select p.value || '\' || t.instance || '_ora_' || ltrim(to_char(p.spid,'fm99999')) || '.trc'

    fromv$processp,v$sessions,v$parameter p,v$thread t

    where p.addr = s.paddr and s.audsid = userenv('sessionid') and p.name = 'user_dump_dest';

 

已 知spid,查看当前正在执行或最近一次执行的语句:

select /*+ ordered */ sql_text fromv$sqltext sql

    where (sql.hash_value, sql.address) in (

        select decode(sql_hash_value, 0, prev_hash_value, sql_hash_value), decode(sql_hash_value, 0, prev_sql_addr, sql_address)

        fromv$sessions where s.paddr = (select addr fromv$processp where p.spid = to_number('&pid')))

    order by piece asc;

 

查 看锁和等待:

col user_name format a10

col owner format a10

col object_name format a15

col sid format 999999

col serial# format 999999

col spid format a6

select /*+ rule */ lpad(' ', decode(l.xidusn, 0, 3, 0)) || l.oracle_username user_name,

    o.owner, o.object_name, o.object_type, s.sid, s.serial#, p.spid

    fromv$locked_object l, dba_objects o,v$sessions,v$processp

    where l.object_id = o.object_id and l.session_id = s.sid and s.paddr = p.addr

    order by o.object_id, xidusn desc;

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

转载于:http://blog.itpub.net/17179887/viewspace-662352/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值