怎么查看oracle表空间,剩余大小,表空间利用

如题所述

1、因为oracle运行在Linux系统下,首先,要连接Linux系统。



2、连上后,进行oracle控制台。输入命令: sqlplus  / as sysdba;



3、在sql命令行,输入: 

SELECT UPPER(F.TABLESPACE_NAME) "表空间名",D.TOT_GROOTTE_MB "表空间大小(M)",D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)",

TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,2),'990.99') || '%' "使用比",F.TOTAL_BYTES "空闲空间(M)",F.MAX_BYTES "最大块(M)"

FROM (SELECT TABLESPACE_NAME,ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTES,

FROM SYS.DBA_FREE_SPACE,GROUP BY TABLESPACE_NAME) F,

(SELECT DD.TABLESPACE_NAME,ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MB,

FROM SYS.DBA_DATA_FILES DD,GROUP BY DD.TABLESPACE_NAME) D,

WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME,ORDER BY 1;



4、这样就可以查看到相应结果。 完成效果图。


温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2018-03-19
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本回答被网友采纳
第2个回答  2011-11-30

给个邮箱,我给个oracle工具你用,很简单很方便的帮你解决你的问题:

在我给你的工具中一样使用用户名和密码以normal模式登陆所在的服务数据库,之后在菜单‘管理’项中有‘表空间信息’打开:

本回答被网友采纳
第3个回答  2011-11-29
select * from dba_tablespaces
结果返回数据库所有表空间数据
第4个回答  2011-12-14
select tablespace_name ,sum(bytes)/1024/1024 from dba_data_files group by tablespace_name;
select tablespace_name ,sum(bytes)/1024/1024 from dba_free_space group by tablespace_name;

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网