失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 查询oracle表空间是否满了 查看Oracle表空间大小的方法

查询oracle表空间是否满了 查看Oracle表空间大小的方法

时间:2021-09-09 13:55:17

相关推荐

查询oracle表空间是否满了 查看Oracle表空间大小的方法

Oracle表空间大小的查看方法应该是我们都需要掌握的知识,下面就为您详细介绍查看Oracle表空间大小的方法,供您参考学习。

在数据库管理中,磁盘空间不足是DBA都会遇到的问题,问题比较常见。

--1查看Oracle表空间大小--已经使用的百分比。

selecta.tablespace_name,a.bytes/1024/1024"SumMB",(a.bytes-b.bytes)/1024/1024"usedMB",b.bytes/1024/1024"freeMB",round(((a.bytes-b.bytes)/a.bytes)*100,2)"percent_used"

from

(selecttablespace_name,sum(bytes)bytesfromdba_data_filesgroupbytablespace_name)a,

(selecttablespace_name,sum(bytes)bytes,max(bytes)largestfromdba_free_spacegroupbytablespace_name)b

wherea.tablespace_name=b.tablespace_name

orderby((a.bytes-b.bytes)/a.bytes)desc

“Sum MB”表示表空间所有的数据文件总共在操作系统占用磁盘空间的大小

比如:test表空间有2个数据文件,datafile1为300MB,datafile2为400MB,那么test表空间的“Sum MB”就是700MB

“userd MB”表示表空间已经使用了多少

“free MB”表示表空间剩余多少

“percent_user”表示已经使用的百分比

--2比如从1中查看到MLOG_NORM_SPACE表空间已使用百分比达到90%以上,可以查看该表空间总共有几个数据文件,每个数据文件是否自动扩展,可以自动扩展的***值。

selectfile_name,tablespace_name,bytes/1024/1024"bytesMB",maxbytes/1024/1024"maxbytesMB"fromdba_data_files

wheretablespace_name='MLOG_NORM_SPACE';

--3比如MLOG_NORM_SPACE表空间目前的大小为19GB,但***每个数据文件只能为20GB,数据文件快要写满,可以增加表空间的数据文件

用操作系统UNIX、Linux中的df -g命令(查看下可以使用的磁盘空间大小)

获取创建表空间的语句:

selectdbms_metadata.get_ddl('TABLESPACE','MLOG_NORM_SPACE')fromdual;

--4确认磁盘空间足够,增加一个数据文件

altertablespaceMLOG_NORM_SPACE

adddatafile'/oracle/oms/oradata/mlog/Mlog_Norm_data001.dbf'

size10Mautoextendonmaxsize20G

--5验证已经增加的数据文件

selectfile_name,file_id,tablespace_namefromdba_data_files

wheretablespace_name='MLOG_NORM_SPACE'

--6如果删除表空间数据文件,如下:

altertablespaceMLOG_NORM_SPACE

dropdatafile'/oracle/oms/oradata/mlog/Mlog_Norm_data001.dbf'

【编辑推荐】

【责任编辑:段燃 TEL:(010)68476606】

点赞 0

如果觉得《查询oracle表空间是否满了 查看Oracle表空间大小的方法》对你有帮助,请点赞、收藏,并留下你的观点哦!

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