Oracle 11g中扩展表空间操作实例代码

 更新时间:2025年09月18日 10:19:19   作者:瑞琪姐  
在 Oracle 11g 中,创建表空间是一个非常重要的步骤,它直接关系到数据库的性能和安全性,这篇文章主要介绍了Oracle 11g中扩展表空间操作的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

在 Oracle 11g 中扩展表空间是常见的数据库管理任务,通常有以下几种核心方法,操作步骤如下:

一、扩展表空间常用方法

方法 1:调整现有数据文件大小 (RESIZE)

适用于磁盘空间充足,且当前数据文件未达上限的情况。

-- 查询当前数据文件路径和大小
SELECT file_name, bytes/1024/1024 AS current_size_mb
FROM dba_data_files
WHERE tablespace_name = 'YOUR_TABLESPACE_NAME';

-- 扩展指定数据文件 (例如扩大到 2GB)
ALTER DATABASE DATAFILE '/u01/oradata/orcl/users01.dbf' RESIZE 2048M;

方法 2:添加新数据文件 (ADD DATAFILE)

适用于无法继续扩大现有文件(如磁盘分区限制)时。

-- 向表空间添加新数据文件 (初始大小 500MB,自动增长 100MB,最大 10GB)
ALTER TABLESPACE YOUR_TABLESPACE_NAME
ADD DATAFILE '/u01/oradata/orcl/users02.dbf'
SIZE 500M
AUTOEXTEND ON
NEXT 100M
MAXSIZE 10240M;

方法 3:启用/修改自动扩展 (AUTOEXTEND)

让数据文件在空间不足时自动增长。

-- 为已有数据文件启用自动扩展
ALTER DATABASE DATAFILE '/u01/oradata/orcl/users01.dbf'
AUTOEXTEND ON
NEXT 50M  -- 每次增长量
MAXSIZE UNLIMITED;  -- 或指定上限 (如 MAXSIZE 2048M)

二、操作前关键检查项

1、确认表空间状态:

SELECT tablespace_name, status, contents FROM dba_tablespaces;

确保状态为 ONLINE

2、验证磁盘空间:

df -h /u01/oradata  # 检查目标挂载点空间

3、查看当前使用情况:

SELECT 
    a.tablespace_name,
    ROUND(a.bytes_alloc / 1024/1024, 2) AS total_mb,
    ROUND((a.bytes_alloc - nvl(b.bytes_free,0)) / 1024/1024, 2) AS used_mb,
    ROUND(nvl(b.bytes_free,0) / 1024/1024, 2) AS free_mb
FROM (SELECT tablespace_name, SUM(bytes) bytes_alloc
      FROM dba_data_files GROUP BY tablespace_name) a
LEFT JOIN (SELECT tablespace_name, SUM(bytes) bytes_free
           FROM dba_free_space GROUP BY tablespace_name) b
ON a.tablespace_name = b.tablespace_name
WHERE a.tablespace_name = 'YOUR_TABLESPACE_NAME';

4、检查当前表空间是RAC还是单机

select * from dba_data_files;
看文件路径是否是“+DATA”开头,如果是具体路径,则是单机,+DATA开头是RAC模式

三、重要注意事项

1、临时表空间扩展:

-- 添加临时文件 (非数据文件)
ALTER TABLESPACE temp ADD TEMPFILE '/u01/oradata/orcl/temp02.dbf' SIZE 1000M;

2、大文件表空间 (Bigfile):

单文件表空间使用 RESIZE 可扩展到 TB 级

不支持添加多个文件

3、文件路径权限:

确保 Oracle 用户 (oracle) 对目标目录有读写权限。

4、最大文件限制:

依赖操作系统文件大小限制(如 Linux 的 ulimit -f)

数据库块大小决定单个文件理论上限(如 32k 块最大 128TB)

四、操作后验证

-- 检查文件新尺寸
SELECT file_name, bytes/1024/1024 AS size_mb, autoextensible, maxbytes/1024/1024 AS max_mb
FROM dba_data_files
WHERE tablespace_name = 'YOUR_TABLESPACE_NAME';

-- 确认表空间可用空间
SELECT tablespace_name, sum(bytes)/1024/1024 AS free_space_mb
FROM dba_free_space
WHERE tablespace_name = 'YOUR_TABLESPACE_NAME'
GROUP BY tablespace_name;

--确认DG是否同步新增数据表空间

五、生产环境建议

1、监控自动化:

部署脚本定期检查表空间使用率(超过85%触发告警)

2、保留冗余空间:

数据文件不要设置 MAXSIZE UNLIMITED,避免磁盘撑爆

3、使用OMF简化管理:

ALTER SYSTEM SET db_create_file_dest='/u01/oradata/orcl';
ALTER TABLESPACE users ADD DATAFILE SIZE 500M; -- 自动生成路径

4、归档模式考虑:

在归档模式下添加文件会产生少量重做日志,高峰时段需评估影响

总结:

扩展表空间的核心是 RESIZE、ADD DATAFILE、AUTOEXTEND 三种操作。建议优先通过添加数据文件实现扩展,避免单文件过大风险。操作前务必确认磁盘空间及文件路径权限,扩展后立即验证结果。对于关键系统,建议配置自动空间监控告警机制。

到此这篇关于Oracle 11g中扩展表空间操作的文章就介绍到这了,更多相关Oracle扩展表空间内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • 最简单的Oracle数据恢复 select as of使用方法

    最简单的Oracle数据恢复 select as of使用方法

    这篇文章主要介绍了最简单的Oracle数据恢复 select as of使用方法,需要的朋友可以参考下
    2015-08-08
  • Oracle19c 创建表空间遇到的坑

    Oracle19c 创建表空间遇到的坑

    昨天部署好oracle19c后,用以前oracle11g的笔记来创建表空间遇到了坑,今天特此把解决过程分享到脚本之家平台,感兴趣的朋友一起看看吧
    2021-10-10
  • Oracle 12C实现跨网络传输数据库详解

    Oracle 12C实现跨网络传输数据库详解

    这篇文章主要给大家介绍了关于Oracle 12C实现跨网络传输数据库的相关资料,文中介绍的非常详细,相信对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-06-06
  • informatical lookup的使用详解

    informatical lookup的使用详解

    本篇文章是对informatical lookup的使用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • oracle scott 解锁步骤

    oracle scott 解锁步骤

    本节主要介绍了oracle scott 解锁的具体步骤,需要的朋友可以参考下
    2014-07-07
  • Oracle临时表空间管理和优化操作

    Oracle临时表空间管理和优化操作

    Oracle临时表空间(Temporary Tablespace)主要用来存储数据库运行中产生的临时对象,例如SQL排序结果集,临时表等,这些对象的生存周期只有会话,本文总结了Oralce中涉及临时表空间的管理和优化操作,需要的朋友可以参考下
    2024-07-07
  • Oracle递归查询简单示例

    Oracle递归查询简单示例

    最近在做一个树状编码管理系统,其中用到了oracle的树状递归查询,下面这篇文章主要给大家介绍了关于Oracle递归查询的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • 快速查出Oracle数据库中锁等待的方法

    快速查出Oracle数据库中锁等待的方法

    这篇文章主要介绍了快速查出Oracle数据库中锁等待的方法,在实际开发中很有应用价值,需要的朋友可以参考下
    2014-08-08
  • oracle 彻底删除方法

    oracle 彻底删除方法

    如果有个别DLL文件无法删除的情况,则不用理会,重新启动,开始新的安装,安装时,选择一个新的目录,则,安装完毕并重新启动后,老的目录及文件就可以删除掉了。
    2009-06-06
  • Oracle中直方图对执行计划的影响详解

    Oracle中直方图对执行计划的影响详解

    这篇文章主要给大家介绍了关于Oracle数据库中直方图对执行计划的影响的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-09-09

最新评论