文章摘要
这篇文章介绍了如何在Oracle数据库中对表空间进行扩容,并总结了相关的操作方法和常见问题。主要内容包括:
1. **查看表空间使用率**:通过SQL语句获取表空间和数据文件的信息,用于评估表空间的使用情况。
2. **扩容方法**:
- 方法一:`alter database datafile` 增大所需表空间的尺寸。
- 方法二:增加数据文件个数,例如通过`alter tablespace`命令添加新数据文件。
- 方法三:设置表空间自动扩展,例如使用`autoextend on next`指定自动扩展大小。
3. **遇到的错误总结**:例如尝试更改文件名失败,以及解决方法是通过OMF管理并直接添加数据文件。文章还特别提醒,自动扩展时单个表空间最大不能超过32G。
总结而言,文章通过实例详细讲解了Oracle表空间扩容的三种方法,并针对常见错误进行了分析和解决技巧的分享。
目录1.查看表空间使用率2.扩容方法一:增大所需表空间大小方法二:增加数据文件个数方法三:设置表空间自动扩展3.遇到的错误总结
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;
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;

扩容有三种方式:
alter database datafile ‘表空间位置’ resize 新的尺寸
例如:
alter database datafile
‘+GBPORCL/GBPORCL/DATAFILE/sysaux.262.1029000091’
resize 5000M;
‘+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
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;
‘+GBPORCL/GBPORCL/DATAFILE/sysaux.262.1029000091’
autoextend on next 500m maxsize 10000m;
SQL 错误 [1276] [99999]: ORA-01276: 无法添加文件 +GBPORCL/GBPORCL/DATAFILE/sysaux.264.1029000091。
相应文件具有一个 Oracle Managed Files 文件名。
以为直接改个名字就可以,但是不可行,
原因:这个表空间是通过OMF管理的,加数据文件的时候,不需要添加具体的路径和文件名,直接添加并指定大小即可: alter tablespace SYSAUX add datafile size xxx;
或者使用方法二
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:oracle表空间扩容详情Oracle 11g 数据库的部署的图文教程浅谈入门级oracle数据库数据导入导出步骤
© 版权声明
文章版权归作者所有,未经允许请勿转载。