100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > Oracle查询会话连接数

Oracle查询会话连接数

时间:2021-07-06 04:21:49

相关推荐

Oracle查询会话连接数

一 列出当前数据库建立的会话情况

不同版本数据库提供的系统表会有不同,你可以根据数据字典查看该版本数据库所提供的表。

select * from dict where table_name like '%SESSION%';

就可以查出一些表,然后根据这些表就可以获得会话信息

select sid,serial#,status,username,schemaname,osuser,terminal,machine,

program,a.name from v$session s,audit_actions a where MAND=a.action;

像这样就是 查询当前正在操作的会话:

DBA要定时对数据库的连接情况进行检查,看与数据库建立的会话数目是不是正常,如果建立了过多的连接,会消耗数据库的资源。同时,对一些“挂死”的连接,可能会需要DBA手工进行清理。

以下的SQL语句列出当前数据库建立的会话情况:

select sid,serial#,username,program,machine,status from v$session;

SID 会话(session)的ID号;

SERIAL# 会话的序列号,和SID一起用来唯一标识一个会话;

USERNAME 建立该会话的用户名;

PROGRAM 这个会话是用什么工具连接到数据库的;

STATUS 当前这个会话的状态,ACTIVE表示会话正在执行某些任务,INACTIVE表示当前会话没有执行任何操作;

如果DBA要手工断开某个会话,则执行:

alter system kill session 'SID,SERIAL#';

注意,上例中SID为1到7(USERNAME列为空)的会话,是Oracle的后台进程,不要对这些会话进行任何操作。

二 查看连接的进程

SELECT SID, SERIAL#, USERNAME, OSUSER FROM V$SESSION;

三 查看连接数

SELECT COUNT (*) FROM v$session;

四 查看连接的并发数

SELECT COUNT(*) FROM V$SESSION WHERE STATUS='ACTIVE';

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。