技术开发 频道

ORACLE数据库日常维护的九大知识点

  【IT168 评论】oracle数据库是一种大型数据库系统,一般应用于商业,政府部门,它的功能很强大,能够处理大批量的数据,在网络方面也用的非常多。首先要说的是,不同版本数据库提供的系统表会有不同,你可以根据数据字典查看该版本数据库所提供的表。

  like this:

  
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 S.COMMAND
= 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 count(*) from v$session #连接数

  Select count(*) from v$session where status='ACTIVE' #并发连接数

  show parameter processes #最大连接

  alter system set processes = value scope = spfile;重启数据库 #修改连接

  1:oracle中怎样查看总共有哪些用户

  select * from all_users;

  2:查看oracle当前连接数

  怎样查看oracle当前的连接数呢?只需要用下面的SQL语句查询一下就可以了。

  select * from v$session where username is not null

  select username,count(username) from v$session where username is not null group by username #查看不同用户的连接数

  select count(*) from v$session #连接数

  Select count(*) from v$session where status='ACTIVE' #并发连接数

  show parameter processes #最大连接

  alter system set process

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

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

0
相关文章