在Oracle中查询表的⼤⼩、表的占⽤情况和表空间的⼤⼩在Oracle中查询表的⼤⼩、表的占⽤情况和表空间的⼤⼩
有两种含义的表⼤⼩。⼀种是分配给⼀个表的物理空间数量,⽽不管空间是否被使⽤。可以这样查询获得字节数:
select segment_name, bytes
from user_segments
where segment_type = 'TABLE';
或者
Select Segment_Name,Sum(bytes)/1024/1024 From User_Extents Group By Segment_Name
另⼀种表实际使⽤的空间。这样查询:
analyze table emp compute statistics;
select num_rows * avg_row_len
from user_tables
where table_name = 'EMP';
查看每个表空间的⼤⼩
Select Tablespace_Name,Sum(bytes)/1024/1024 From Dba_Segments Group By Tablespace_Name
1.查看剩余表空间⼤⼩
SELECT tablespace_name 表空间,sum(blocks*8192/1000000) 剩余空间M FROM dba_free_space GROUP BY
tablespace_name;
2.检查系统中所有表空间总体空间
select b.name,sum(a.bytes/1000000)总空间 from v$datafile a,v$tablespace b where a.ts#=b.ts# group by b.name;
  1、查看Oracle数据库中表空间信息的⼯具⽅法:
  使⽤oracle enterprise manager console⼯具,这是oracle的客户端⼯具,当安装oracle服务器或客户端时会⾃动安装此⼯具,在windows操作系统上完成oracle安装后,通过下⾯的⽅法登录该⼯具:开始菜单——程序——Oracle-OraHome92——Enterprise Manager Console(单击)——oracle enterprise manager console登录——选择‘独⽴启动’单选框——‘确定’ —— ‘oracle enterprise manager console,独⽴’ ——选择要登录的‘实例名’ ——弹出‘数据库连接信息’ ——输⼊’⽤户名/⼝令’ (⼀般使⽤sys⽤户),’连接⾝份’选择选择SYSDBA——‘确定’,这时已经成功登录该⼯具,选择‘存储’ ——表空间,会看到如下的界⾯,该界⾯显⽰了表空间名称,表空间类型,区管理类型,以”兆”为单位的表空间⼤⼩,已使⽤的表空间⼤⼩及表空间利⽤率。
  图1 表空间⼤⼩及使⽤率
  2、查看Oracle数据库中表空间信息的命令⽅法:
  通过查询数据库系统中的数据字典表(data dictionary tables)获取表空间的相关信息,⾸先使⽤客户端⼯具连接到数据库,这些⼯具可以是SQLPLUS字符⼯具、TOAD、PL/SQL等,连接到数据库后执⾏如下的查询语句:
  select
  a.a1 表空间名称,
  c.c2 类型,
  c.c3 区管理,
  b.b2/1024/1024 表空间⼤⼩M,
  (b.b2-a.a2)/1024/1024 已使⽤M,
  substr((b.b2-a.a2)/b.b2*100,1,5) 利⽤率
oracle登录命令
  from
  (select tablespace_name a1, sum(nvl(bytes,0)) a2 from dba_free_space group by tablespace_name) a,
  (select tablespace_name b1,sum(bytes) b2 from dba_data_files group by tablespace_name) b,
  (select tablespace_name c1,contents c2,extent_management c3 from dba_tablespaces) c
  where a.a1=b.b1 and c.c1=b.b1;
  该语句通过查询dba_free_space,dba_data_files,dba_tablespaces这三个数据字典表,得到了表空间名称,表空间类型,区管理类型,以”兆”为单位的表空间⼤⼩,已使⽤的表空间⼤⼩及表空间利⽤率。dba_free_space表描述了表空间的空闲⼤
⼩,dba_data_files表描述了数据库中的数据⽂件,dba_tablespaces表描述了数据库中的表空间。
  上⾯语句中from⼦句后有三个select语句,每个select语句相当于⼀个视图,视图的名称分别为a、b、c,通过它们之间的关联关系,我们得到了表空间的相关信息。
  语句执⾏结果如下:
表空间名称类型区管理表空间⼤⼩M已使⽤M利⽤率
CWMLITE PERMANENT LOCAL209.37546.87
DRSYS PERMANENT LOCAL209.687548.43
EXAMPLE PERMANENT LOCAL149.375149.2599.91
INDX PERMANENT LOCAL250.06250.25
ODM PERMANENT LOCAL209.37546.87
SYSTEM PERMANENT LOCAL400397.37599.34
TOOLS PERMANENT LOCAL10  6.062560.62
UNDOTBS1UNDO LOCAL200  5.9375  2.968
USERS PERMANENT LOCAL250.06250.25
XDB PERMANENT LOCAL38.12537.937599.5
  上⾯描述中分别介绍了查看Oracle数据库中表空间信息的⼯具⽅法和命令⽅法。
  1、查看Oracle数据库中数据⽂件信息的⼯具⽅法:
  使⽤上⾯介绍过的⽅法登录oracle enterprise manager console⼯具,选择‘存储’ ——数据⽂件,会看到如下的界⾯,该界⾯显⽰了数据⽂件名称,表空间名称,以”兆”为单位的数据⽂件⼤⼩,已使⽤的数据⽂件⼤⼩及数据⽂件利⽤率。
  图2 数据⽂件⼤⼩及使⽤率
2、查看Oracle数据库中数据⽂件信息的命令⽅法:
  通过查询数据库系统中的数据字典表(data dictionary tables)获取数据⽂件的相关信息,⾸先使⽤客户端⼯具连接到数据库,这些⼯具可以是SQLPLUS字符⼯具、TOAD、PL/SQL等,连接到数据库后执⾏如下的查询语句:
  select
  b.file_name 物理⽂件名,
  b.tablespace_name 表空间,
  b.bytes/1024/1024 ⼤⼩M,
  (b.bytes-sum(nvl(a.bytes,0)))/1024/1024 已使⽤M,
  substr((b.bytes-sum(nvl(a.bytes,0)))/(b.bytes)*100,1,5) 利⽤率
  from dba_free_space a,dba_data_files b
  where a.file_id=b.file_id
  group by b.tablespace_name,b.file_name,b.bytes
  order by b.tablespace_name
  语句执⾏结果如下:
物理⽂件名表空间⼤⼩M已使⽤M利⽤率
G:/ORACLE/ORADATA/ORA92/CWMLITE01.DBF CWMLITE209.37546.87
G:/ORACLE/ORADATA/ORA92/DRSYS01.DBF DRSYS209.687548.43
G:/ORACLE/ORADATA/ORA92/EXAMPLE01.DBF EXAMPLE149.375149.2599.91
G:/ORACLE/ORADATA/ORA92/INDX01.DBF INDX250.06250.25
G:/ORACLE/ORADATA/ORA92/ODM01.DBF ODM209.37546.87
G:/ORACLE/ORADATA/ORA92/SYSTEM01.DBF SYSTEM400397.37599.34
G:/ORACLE/ORADATA/ORA92/TOOLS01.DBF TOOLS10  6.062560.62
G:/ORACLE/ORADATA/ORA92/UNDOTBS01.DBF UNDOTBS1200  5.9375  2.968
G:/ORACLE/ORADATA/ORA92/USERS01.DBF USERS250.06250.25
G:/ORACLE/ORADATA/ORA92/XDB01.DBF XDB38.12537.937599.5
  上明描述中分别介绍了查看Oracle数据库中数据⽂件信息的⼯具⽅法和命令⽅法。
  在oracle数据库中,临时表空间主要⽤于⽤户在使⽤order by 、group by语句进⾏排序和汇总时所需的临时⼯作空间。要查询数据库中临时表空间的名称,⼤⼩及数据⽂件,可以查询数据字典dba_tablespaces及dba_data_files。命令如下:
  select
  a.talbespace_name 表空间名称,
  b.bytes ⼤⼩bytes,
  b.file_name 数据⽂件名
  from dba_tablespaces a, dba_data_files b
  Where a.talbespace_name=b.talbespace_name ts=’TEMPORARY’;
  查询结果如下:
  表空间名称⼤⼩bytes数据⽂件名
  TEMPONLINEG:/ORACLE/ORADATA/ORA92/TEMP01.DBF
  从oracle 9i开始,可以创建Temporary tablespace类表空间,即“临时“表空间,这类表空间使⽤临时⽂件。临时⽂件的信息被存储在数据字典V$tempfile中。命令如下:
  Select file#,status,name from V$tempfile;
  查询数据字典V$tempfile结果如下:
FILE#status NAME
1ONLINE G:/ORACLE/ORADATA/ORA92/TEMP01.DBF
  在上⾯介绍的⽅法中,建议掌握命令⽅法,因为你的环境可能没有图形⼯具,⽽SQLPLUS⼀般情况下都是可以使⽤的,有了命令脚本,很容易得到表空间和数据⽂件的相关信息。另外,数据库管理员应该多整理命令脚本,在需要时直接执⾏脚本以提⾼⼯作效率。
  在数据库管理员的⽇常⼯作中,应该经常查询表空间的利⽤率,按照数据库系统的具体情况估算表空间的增长量,当表空间的利⽤率超过90%时,要及时采取措施,如清理历史表、历史数据以释放空间,向表空间中添加新的数据⽂件,扩展现有数据⽂件⼤⼩等⽅法来降低表空间的利⽤率,避免表空间利⽤率接近100%时,将产⽣空间不够的错误。
1.查询oracle表空间的使⽤情况
select b.file_id  ⽂件ID,
  b.tablespace_name  表空间,
  b.file_name     物理⽂件名,
  b.bytes       总字节数,
  (b.bytes-sum(nvl(a.bytes,0)))   已使⽤,
  sum(nvl(a.bytes,0))        剩余,
  sum(nvl(a.bytes,0))/(b.bytes)*100 剩余百分⽐
  from dba_free_space a,dba_data_files b
  where a.file_id=b.file_id
  group by b.tablespace_name,b.file_name,b.file_id,b.bytes
  order by b.tablespace_name
2.查询oracle系统⽤户的默认表空间和临时表空间
select default_tablespace,temporary_tablespace from dba_users
3.查询单张表的使⽤情况
select segment_name,bytes from dba_segments where segment_name = 'RE_STDEVT_FACT_DAY' and owner = USER
RE_STDEVT_FACT_DAY是您要查询的表名称
4.查询所有⽤户表使⽤⼤⼩的前三⼗名
select * from (select segment_name,bytes from dba_segments where owner = USER order by bytes desc ) where rownum
<= 30
5.查询当前⽤户默认表空间的使⽤情况
select tablespacename,sum(totalContent),sum(usecontent),sum(sparecontent),avg(sparepercent)
from
(
SELECT b.file_id as id,b.tablespace_name as tablespacename,b.bytes as totalContent,(b.bytes-sum(nvl(a.bytes,0))) as usecontent,sum(nvl(a.bytes,0)) as sparecontent,sum(nvl(a.bytes,0))/(b.bytes)*100  as sparepercent
FROM dba_free_space a,dba_data_files b
WHERE a.file_id=b.file_id and b.tablespace_name = (select default_tablespace from dba_users where username = user)  group by b.tablespace_name,b.file_name,b.file_id,b.bytes
)
GROUP BY tablespacename

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。