ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数
SQL> ALTER DATABASE DATAFILE'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300m;
ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA'RESIZE 300m
*
ERROR 位于第 1 行:
ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据
ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA'RESIZE 300m
*
ERROR 位于第 1 行:
ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据
但是
SQL>select d.filename,d.file_id,d.bytes/1024/1024 asd_byte,sum(f.bytes/1024/1024) as free_byte
2
from dba_data_filesd,dba_free_space f
3
whered.file_id=f.file_id and d.file_id=18
4
group byd.file_name,d.file_id,d.bytes/1024/1024;
FILE_NAME FILE_ID D_BYTE FREE_BYTE
--------------------------------- ---------- ---------- ----------
D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA 18 1536 1482.0625
可以看到实际上ID=18的文件只使用了大概50M左右,只是数据分布在(按一定的顺序)50M甚至在300M以外的地方,所以这里虽然看到只使用了约50M空间,但是却不能resizedatafile.
为此,要改小数据文件,我们先要对文件上的表和索引移动一下位置,具体做法如下:
SQL>altertablespace ic_data coalesce;
SQL>select segment_name,partition_name,segment_type
2
from dba_extents
3
where file_id=18;
SQL> set heading off
SQL> set echo off
SQL> set feedback off
SQL> set termout on
SQL> spool d:\aaa.sql
SQL> set echo off
SQL> set feedback off
SQL> set termout on
SQL> spool d:\aaa.sql
//移动表
SQL>select DISTINCT 'alter table '|| segment_name || ' movetablespace test_space;' from dba_extents where segment_type='TABLE'and file_id=18;
//移动索引
SQL>select DISTINCT 'alter
index '||segment_name || '
rebuild tablespace test_space;'from dba_extents where segment_type='INDEX' and file_id=18;
//移动分区表
SQL>select DISTINCT 'alter table '|| segment_name || ' movepartition '|| partition_name || ' tablespace test_space;' fromdba_extents where segment_type='TABLE PARTITION' andfile_id=18;
//移动分区索引
SQL>select DISTINCT 'alter
index '||segment_name || '
rebuild partition '||partition_name || ' tablespace test_space;' from dba_extents wheresegment_type='INDEX PARTITION' and file_id=18;
SQL>spool off
然后执行aaa.sql,注意保证test_space有足够的空间容纳这些数据,
其实可以不移动所有的数据,但是总的测验是不是移动了300M以外的数据,所以还是移动所有数据的方便
SQL> c/9/3
SQL> /
数据库已更改。
select 'alter database datafile ''' || a.file_name || ''' resize ' ||
round(a.filesize - (a.filesize - c.hwmsize - 100) * 0.8) || 'M;',
a.filesize || 'M' as "数据文件的总大小",
c.hwmsize || 'M' as "数据文件的实用大小"
from (select file_id, file_name, round(bytes / 1024 / 1024) as filesize
from dba_data_files) a,
(select file_id, round(max(block_id) * 8 / 1024) as HWMsize
from dba_extents
group by file_id) c
where a.file_id = c.file_id
and a.filesize - c.hwmsize > 100;