在我的系统中,永久数据与一些临时数据(如日志)分开。这是通过将日志表(用户定义的程序日志,不要与系统日志混淆)存储在与主表不同的表空间中来完成的。
所以有两个表空间MAIN
和LOG
. 每个表空间对应一个数据文件。两个数据文件的 maxsize 都设置为 4GB,它们的初始大小为 8MB,并且它们在下一个 8MB 时自动扩展。
由于我使用的是 oracle 的 express 版本,所以我需要它们的总和不超过 4GB。
当我需要减小 LOG 数据文件的大小以便为必要的数据腾出一些空间时,有时会发生这种情况。
现在我这样做:
truncate table schema_name.log_table;
alter database datafile '/path/to/the/log/datafile/log1.dbf' resize 128M;
它有效,因为truncate
删除了数据文件中的所有信息。
但是,如果我遇到需要从 MAIN 表空间中释放一些 LOG 表空间大小的情况怎么办。我在那里截断了几个表(或者我知道数据文件中有很多可用空间,它已分配但未被数据占用,之前用于某些操作),现在需要对 MAIN 表空间的数据文件进行碎片整理以减小其大小。没有碎片整理我得到一个例外:
ORA-03297: file contains used data beyond requested RESIZE value
那么我是否能够以某种方式对数据文件执行碎片整理操作?