关于oracle数据库表空间扩容的问题
1.查看表空间使用率
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.扩容
扩容有三种方式:
方法一:增大所需表空间大小
alter database datafile '表空间位置' resize 新的尺寸
例如:
alter database datafile '+GBPORCL/GBPORCL/DATAFILE/sysaux.262.1029000091' resize 5000M;
注意:单个表空间最大为32G;
对于oracle数据库的表空间,除了用手动增加数据文件大小外,还可以增加数据文件数量等方式扩展表空间大小。
方法二:增加数据文件个数
alter tablespace 表空间名称 add datafile '新的数据文件地址' size 数据文件大小
例如:
ALTER TABLESPACE "SYSAUX" ADD DATAFILE '+GBPORCL/GBPORCL/DATAFILE/sysaux.272.dbf' SIZE 100M AUTOEXTEND ON next 50M Maxsize UNLIMITED
含义:初始分配100M,自增50M;
方法三:设置表空间自动扩展
alter database datafile '数据文件位置' autoextend on next 自动扩展大小 maxsize 最大扩展大小
例如:
alter database datafile '+GBPORCL/GBPORCL/DATAFILE/sysaux.262.1029000091' autoextend on next 500m maxsize 10000m;
3.遇到的错误
SQL 错误 [1276] [99999]: ORA-01276: 无法添加文件 +GBPORCL/GBPORCL/DATAFILE/sysaux.264.1029000091。
相应文件具有一个 Oracle Managed Files 文件名。
以为直接改个名字就可以,但是不可行,
原因:这个表空间是通过OMF管理的,加数据文件的时候,不需要添加具体的路径和文件名,直接添加并指定大小即可: alter tablespace SYSAUX add datafile size xxx;
或者使用方法二
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Oracle中ROW_NUMBER()OVER()函数用法实例讲解
Oracle中的row_number()函数用于在查询结果中为每一行生成一个唯一的行号,下面这篇文章主要给大家介绍了关于Oracle中ROW_NUMBER()OVER()函数用法的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2023-04-04
windows使用sqlpus连接oracle 数据库的教程图解
这篇文章主要介绍了windows使用sqlpus连接oracle 数据库的教程图解,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下2019-08-08
ORA-00947:Not enough values (没有足够的值)的深入分析
本篇文章是对ORA-00947:Not enough values (没有足够的值)的解决方法进行了详细的分析介绍,需要的朋友参考下2013-05-05


最新评论