Tablespace Used MB Free MB Total MB
------------------------------ ---------- ---------- ----------
DATA_S1 686 295 981我们有一个名为DATA_S1的表空间,它包含一个数据文件。正如我们所看到的,大约300米的数据文件空间是未使用的。如果我试图通过以下方式将数据文件缩小200M:
alter tablespace TABLESPACE_NAME datafile 'DATAFILE_NAME' resize 800M;它规定:
ORA-03297: file contains used data beyond requested RESIZE value.不管怎样,我可以从数据文件中收回空间吗?
发布于 2015-10-29 15:48:19
在调整大小之前,必须删除数据文件中的碎片。这意味着每个段(分配给该表空间中每个对象的块集)都需要将其db块中的所有行集合在一起。
为此,您有几种选择:
如果你在11 gR2上,你可以用
ALTER TABLESPACE <TABLESPACE_NAME> SHRINK SPACE KEEP 700M;这将删除碎片并缩小相关的数据文件,此外,它还将将HWM设置在“最低”的可能位置。
注意:这是一种n/O密集型操作,不要在工作时间或生产环境的维护窗口外执行。
可以使用的另一个选项是创建碎片数据文件的“备份作为副本”,然后切换数据库以指向这些“图像副本”。然后删除原始和重做使用图像副本作为原件,并支持他们“复制”到原来的位置。这是一个更长和更复杂的,但“停机时间”只是几秒钟,而切换是执行。
有关此选项的详细信息,请参阅甲骨文数据库11.2 RMAN参考手册。
希望这能帮到你。
如果没有,请在问题中添加更多细节。如软件版本,维护窗口时间,接受停机时间等。
https://dba.stackexchange.com/questions/119531
复制相似问题