首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从oracle中的数据文件中回收未使用的空间

从oracle中的数据文件中回收未使用的空间
EN

Database Administration用户
提问于 2015-10-29 09:59:24
回答 1查看 5K关注 0票数 1
代码语言:javascript
复制
Tablespace                        Used MB    Free MB   Total MB
------------------------------ ---------- ---------- ----------

 DATA_S1                               686        295        981

我们有一个名为DATA_S1的表空间,它包含一个数据文件。正如我们所看到的,大约300米的数据文件空间是未使用的。如果我试图通过以下方式将数据文件缩小200M:

代码语言:javascript
复制
alter tablespace TABLESPACE_NAME datafile 'DATAFILE_NAME' resize 800M;

它规定:

代码语言:javascript
复制
ORA-03297: file contains used data beyond requested RESIZE value.

不管怎样,我可以从数据文件中收回空间吗?

EN

回答 1

Database Administration用户

发布于 2015-10-29 15:48:19

在调整大小之前,必须删除数据文件中的碎片。这意味着每个段(分配给该表空间中每个对象的块集)都需要将其db块中的所有行集合在一起。

为此,您有几种选择:

如果你在11 gR2上,你可以用

代码语言:javascript
复制
ALTER TABLESPACE <TABLESPACE_NAME> SHRINK SPACE KEEP 700M;

这将删除碎片并缩小相关的数据文件,此外,它还将将HWM设置在“最低”的可能位置。

注意:这是一种n/O密集型操作,不要在工作时间或生产环境的维护窗口外执行。

可以使用的另一个选项是创建碎片数据文件的“备份作为副本”,然后切换数据库以指向这些“图像副本”。然后删除原始和重做使用图像副本作为原件,并支持他们“复制”到原来的位置。这是一个更长和更复杂的,但“停机时间”只是几秒钟,而切换是执行。

有关此选项的详细信息,请参阅甲骨文数据库11.2 RMAN参考手册

希望这能帮到你。

如果没有,请在问题中添加更多细节。如软件版本,维护窗口时间,接受停机时间等。

票数 1
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/119531

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档