在Oracle中查询表的大小和表空间的大小
上一篇 / 下一篇  2011-08-28 11:59:01 / 个人分类:计算机
查看( 443 ) / 评论( 0 ) / 评分( 0 / 0 )
原文:blog.csdn/cosio/article/details/3978747
有两种含义的表大小。一种是分配给一个表的物理空间数量,而不管空间是否被使用。可以这样查询获得字节数:ITPUB个人空间'U+B-A/s2ut(f^k
ITPUB个人空间X+A9IO&@4l t
select segment_name, bytes
g*M h m!u`!tU-U4ZyY0from user_segmentsITPUB个人空间'O
X3H!B-XB_XD
where segment_type = 'TABLE';ITPUB个人空间sH:^ G,V
或者ITPUB个人空间4Q ^8_8KmP$~)hT(C
   Select Segment_Name,Sum(bytes)/1024/1024 From User_Extents Group By Segment_Name
u$Z$B#rL)@0S0
*K:RYGNu"|&@6K0另一种表实际使用的空间。这样查询:ITPUB个人空间t2r+^+st KF5p
H"db+b6py#v9H0analyze table emp compute statistics;
g;RF$@:X~wQ0select num_rows * avg_row_len
2hY.w5l[*c'K;Q0from user_tables
Rb!m_ @e0where table_name = 'EMP';ITPUB个人空间.D*k+v x2E9v P
.Auf-sH&SO%I
\o3_0查看每个表空间的大小
iC
Z8oDR[x0Select 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) 利用率
  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
LOCAL
20
9.375
46.87
DRSYS
PERMANENT
LOCAL
20
9.6875
48.43
EXAMPLE
PERMANENT
LOCAL
149.375
149.25
99.91
INDX
PERMANENT
LOCAL
25
0.0625
0.25
ODM
PERMANENT
LOCAL
20
9.375
46.87
SYSTEM
PERMANENT
LOCAL
400
397.375
99.34
TOOLS
PERMANENT
LOCAL
10
6.0625
60.62
UNDOTBS1
UNDO
LOCAL
200
5.9375
2.968
USERS
PERMANENT
LOCAL
25
0.0625
0.25
XDB
PERMANENT
LOCAL
38.125
37.9375
99.5
  上面描述中分别介绍了查看Oracle数据库中表空间信息的工具方法和命令方法。
 
  1、查看Oracle数据库中数据文件信息的工具方法:
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
CWMLITE
20
9.375
46.87
G:/ORACLE/ORADATA/ORA92/DRSYS01.DBF
DRSYS
20
9.6875
48.43
G:/ORACLE/ORADATA/ORA92/EXAMPLE01.DBF
EXAMPLE
149.375
149.25
99.91
G:/ORACLE/ORADATA/ORA92/INDX01.DBF
INDX
25
0.0625
0.25
G:/ORACLE/ORADATA/ORA92/ODM01.DBF
ODM
20
9.375
46.87
G:/ORACLE/ORADATA/ORA92/SYSTEM01.DBF
SYSTEM
400
397.375
99.34
G:/ORACLE/ORADATA/ORA92/TOOLS01.DBF
TOOLS
10
6.0625
60.62
G:/ORACLE/ORADATA/ORA92/UNDOTBS01.DBF
UNDOTBS1
200
5.9375
2.968
G:/ORACLE/ORADATA/ORA92/USERS01.DBF
USERS
25
0.0625
0.25
G:/ORACLE/ORADATA/ORA92/XDB01.DBF
XDB
38.125
37.9375
99.5
  上明描述中分别介绍了查看Oracle数据库中数据文件信息的工具方法和命令方法。

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