经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » Oracle » 查看文章
关于oracle数据库表空间扩容的问题
来源:jb51  时间:2023/2/17 9:59:06  对本文有异议

1.查看表空间使用率

  1. SELECT
  2. B.FILE_NAME 物理文件名,
  3. B.TABLESPACE_NAME 表空间名称,
  4. B.BYTES/1024/1024 大小M,
  5. (B.BYTES-SUM(NVL(A.BYTES,0)))/1024/1024 已使用M,
  6. SUBSTR((B.BYTES-SUM(NVL(A.BYTES,0)))/(B.BYTES)*100,1,5) 使用率
  7. FROM DBA_FREE_SPACE A,DBA_DATA_FILES B
  8. WHERE A.FILE_ID=B.FILE_ID
  9. GROUP BY B.TABLESPACE_NAME,B.FILE_NAME,B.BYTES
  10. ORDER BY B.TABLESPACE_NAME;

2.扩容

扩容有三种方式:

方法一:增大所需表空间大小

alter database datafile '表空间位置' resize 新的尺寸

例如:

  1. alter database datafile
  2. '+GBPORCL/GBPORCL/DATAFILE/sysaux.262.1029000091'
  3. resize 5000M;

注意:单个表空间最大为32G;

对于oracle数据库的表空间,除了用手动增加数据文件大小外,还可以增加数据文件数量等方式扩展表空间大小。

方法二:增加数据文件个数

alter tablespace 表空间名称 add datafile '新的数据文件地址' size 数据文件大小

例如: 

  1. ALTER TABLESPACE "SYSAUX"
  2. ADD DATAFILE '+GBPORCL/GBPORCL/DATAFILE/sysaux.272.dbf'
  3. SIZE 100M AUTOEXTEND ON next 50M Maxsize UNLIMITED

含义:初始分配100M,自增50M;

方法三:设置表空间自动扩展

alter database datafile '数据文件位置' autoextend on next 自动扩展大小 maxsize 最大扩展大小

例如:

  1. alter database datafile
  2. '+GBPORCL/GBPORCL/DATAFILE/sysaux.262.1029000091'
  3. 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;

或者使用方法二 

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号