Oracle V$SESSION

SADDR session address
SID session identifier 常用于链接其他列
SERIAL# SID有可能会重复,当两个session的SID重复时,SERIAL#用来区别session(说白了某个session是由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
USER# 同于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$loc中的sid + kaddr相对应.
STATUS 用来判断session状态.Active:正执行SQL语句.inactive:等待操作.killed:被标注为杀死.
SERVER 服务类型.
SCHEMA# schema user id.Oracle内部进程的schema#为0.
SCHEMANAME schema username.Oracle内部进程的为sys.
OSUSER 客户端操作系统用户名.
PROCESS 客户端process id.
MACHINE 客户端machine name.
TERMINAL 客户端执行的terminal name.
PROGRAM 客户端应用程序.比如ORACLE.EXE或sqlplus.exe
TYPE session类型.
SQL_ADDRESS,
SQL_HASH_VALUE,
SQL_ID,SQL_CHILD_NUMBER
session正在执行的sql状态,和v$sql中的address,hash_value,sql_id,child_number对应.
PREV_SQL_ADDR,
PREV_HASH_VALUE,
PREV_SQL_ID,
PREV_CHILD_NUMBER
上一次执行的sql状态.
MODULE,
MODULE_HASH,
ACTION,
ACTION_HASH,
CLIENT_INFO
应用通过DBMS_APPLICATION_INFO设置的一些信息.
FIXED_TABLE_SEQUENCE 当session完成一个user call后就会增加的一个数值,也就是说,如果session挂起,它就不会增加.因此可以根据这个字段来监控某个时间点以来的session性能情况.例如,一个小时前某个session的此字段数值为10000,而现在是20000,则表明一个小时内其user call较频繁,可以重点关注此session的performance statistics.
ROW_WAIT_OBJ# 被锁定行所在table的object_id.和dba_object中的object_id关联可以得到被锁定的table name.
ROW_WAIT_FILE# 被锁定行所在的datafile id.和v$datafile中的file#关联可以得到datafile name.
ROW_WAIT_BLOCK# 同上,对应块.
ROW_WAIT_ROW# session当前正在等待的被锁定的行.
LOGON_TIME session logon time.

查询锁住对象的会话信息:

SELECT OBJECT_NAME, MACHINE, S.SID, S.SERIAL#
FROM GV$LOCKED_OBJECT L, DBA_OBJECTS O, GV$SESSION S
WHERE L.OBJECT_ID  = O.OBJECT_ID
AND L.SESSION_ID = S.SID;

销毁会话:

ALTER SYSTEM KILL SESSION 'SID, #SERIAL';

查看当前会话所执行的语句以及会话相关信息:

SELECT A.SID, A.SERIAL#, A.USERNAME, A.TERMINAL, A.PROGRAM, S.SQL_TEXT
FROM V$SESSION A, V$SQLAREA S
WHERE A.SQL_ADDRESS = S.ADDRESS(+)
AND A.SQL_HASH_VALUE = S.HASH_VALUE(+)
ORDER BY A.USERNAME, A.SID;
上一篇:15个实用的Linux find命令示例(一)


下一篇:每天点滴的进行,css+div简单布局...布局