精华内容
下载资源
问答
  • 如果直接修改数据文件的大小,可能会遇到如下错误:ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据 情况二:发现表空间剩余80%,故想收缩一下表空间,但是报ORA-03297错误,分析为数据分布不一致或者后续删除...

    情况一:将备份的一个大数据库还原到本机以后,删除里面的大表(比如文件表、日志表等),
    Oracle数据文件在有数据的情况下能自动扩展,却不能自动收缩,造成存储空间的浪费。
    如果直接修改数据文件的大小,可能会遇到如下错误:ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据

    情况二:发现表空间剩余80%,故想收缩一下表空间,但是报ORA-03297错误,分析为数据分布不一致或者后续删除大表导致,解决方法如下:

    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 值以外使用的数据
    但是
    先查出数据文件的file_id号,然后查空间使用情况
    SQL>select d.file_name,d.file_id,d.bytes/1024/1024 as d_byte,sum(f.bytes/1024/1024) as free_byte
    2 from dba_data_files d,dba_free_space f
    3 where d.file_id=f.file_id and d.file_id=18
    4 group by d.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空间,但是却不能resize datafile.
    为此,要改小数据文件,我们先要对文件上的表和索引移动一下位置,具体做法如下:
    1、移动表前先对表空间做整理
    SQL>alter tablespace ic_data coalesce;
    2、在dba_extents找到与ID=18的数据文件相关的表及索引
    SQL>select segment_name,partition_name,segment_type
    2 from dba_extents
    3 where file_id=18;
    3、对id=18的文件上的表和索引移动位置
    SQL> set heading off
    SQL> set echo off
    SQL> set feedback off
    SQL> set termout on
    SQL> spool d:\aaa.sql
    //移动表
    SQL>select DISTINCT 'alter table ‘|| segment_name || ’ move tablespace 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 || ’ move partition ‘|| partition_name || ’ tablespace test_space;’ from dba_extents where segment_type=‘TABLE PARTITION’ and file_id=18;
    //移动分区索引
    SQL>select DISTINCT 'alter index '|| segment_name || ’ rebuild partition ‘|| partition_name || ’ tablespace test_space;’ from dba_extents where segment_type=‘INDEX PARTITION’ and file_id=18;
    SQL>spool off
    然后执行aaa.sql,注意保证test_space有足够的空间容纳这些数据,
    其实可以不移动所有的数据,但是总的测验是不是移动了300M以外的数据,所以还是移动所有数据的方便
    4、这样移动了所有的数据以后就可以对datafile resize了
    SQL> c/9/3
    1* ALTER DATABASE DATAFILE ‘D:\Oracle\ORADATA\ICAPP\IC_DATA6.ORA’ RESIZE 300M
    SQL> /

    数据库已更改。

    5、把原来表空间ic_data中的数据再移动回来,修改aaa.sql中的表空间名为ic_data再执行,然后drop tablespace test_space including contents and datafiles。

    以上操作起源于删除了database里的一个大表造成很多空间浪费,想回收空间
    经过实践,以上方法可以处理ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据问题。
    但是如果一个表空间被多个Oracle用户使用,在导出sql文件时要指定用户,否则在执行sql文件时会报错。
    顶 0 踩
    来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29578568/viewspace-2141576/,如需转载,请注明出处,否则将追究法律责任。

    转载于:http://blog.itpub.net/29578568/viewspace-2141576/

    展开全文
  • Oracle调整表空间大小—ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据 将备份的一个大数据库还原到本机以后,删除里面的大表(比如文件表、日志表等),Oracle数据文件在有数据的情况...

    Oracle调整表空间大小—ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据

    将备份的一个大数据库还原到本机以后,删除里面的大表(比如文件表、日志表等),Oracle数据文件在有数据的情况下能自动扩展,却不能自动收缩,造成存储空间的浪费。
    起源于我删除了database里的一个大表造成很多空间浪费,想回收空间
    如果直接修改数据文件的大小,可能会遇到如下错误:ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据

    转载网址:http://blog.sina.com.cn/s/blog_54eeb5d901000bvg.html

    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 值以外使用的数据

    但是

    SQL>select d.file_name,d.file_id,d.bytes/1024/1024 as d_byte,sum(f.bytes/1024/1024) as free_byte

    2   from dba_data_files d,dba_free_space f

    3   where d.file_id=f.file_id and d.file_id=18

    4   group by d.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空间,但是却不能resize datafile.

    为此,要改小数据文件,我们先要对文件上的表和索引移动一下位置,具体做法如下:

     1、移动表前先对表空间做整理

    SQL>alter tablespace ic_data coalesce;

     2、在dba_extents找到与ID=18的数据文件相关的表及索引

    SQL>select segment_name,partition_name,segment_type

    2   from dba_extents

    3   where file_id=18;

     3、对id=18的文件上的表和索引移动位置

    SQL> set heading off
    SQL> set echo off
    SQL> set feedback off
    SQL> set termout on
    SQL> spool d:\aaa.sql

    //移动表

    SQL>select DISTINCT 'alter table '|| segment_name || ' move tablespace 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 || ' move partition '|| partition_name || ' tablespace test_space;' from dba_extents where segment_type='TABLE PARTITION' and file_id=18;

    //移动分区索引

    SQL>select DISTINCT 'alter index '|| segment_name || ' rebuild partition '|| partition_name || ' tablespace test_space;' from dba_extents where segment_type='INDEX PARTITION' and file_id=18;

    SQL>spool off 

    然后执行aaa.sql,注意保证test_space有足够的空间容纳这些数据,

    先要新建test_space空间,把数据移动到新表空间中,缩小原表空间,将数据移动回原表空间,删除test_space空间

    其实可以不移动所有的数据,但是总的测验是不是移动了300M以外的数据,所以还是移动所有数据的方便

     4这样移动了所有的数据以后就可以对datafile resize了

    SQL>  ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300M
    数据库已更改。

     5把原来表空间ic_data中的数据再移动回来,修改aaa.sql中的表空间名为ic_data再执行,然后drop tablespace test_space including contents and datafiles。

     

    -----------------------分割线-----------------------------分割线-----------------------------分割线----------------------------

    经过实践,以上方法可以处理ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据问题。

    但是如果一个表空间被多个Oracle用户使用,在导出sql文件时要指定用户,否则在执行sql文件时会报错。

     

    来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29578568/viewspace-2151594/,如需转载,请注明出处,否则将追究法律责任。

    转载于:http://blog.itpub.net/29578568/viewspace-2151594/

    展开全文
  • 将备份的一个大数据库还原到本机以后,...如果直接修改数据文件的大小,可能会遇到如下错误:ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据 转载网址:http://blog.sina.com.cn/s/blog_54eeb5d901000bvg.ht

    将备份的一个大数据库还原到本机以后,删除里面的大表(比如文件表、日志表等),Oracle数据文件在有数据的情况下能自动扩展,却不能自动收缩,造成存储空间的浪费。
    如果直接修改数据文件的大小,可能会遇到如下错误:ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据

    转载网址:http://blog.sina.com.cn/s/blog_54eeb5d901000bvg.html

    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 值以外使用的数据
    但是
    SQL>select d.filename,d.file_id,d.bytes/1024/1024 as d_byte,sum(f.bytes/1024/1024) as free_byte
    2   from dba_data_files d,dba_free_space f
    3   where d.file_id=f.file_id and d.file_id=18
    4   group by d.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空间,但是却不能resize datafile.
    为此,要改小数据文件,我们先要对文件上的表和索引移动一下位置,具体做法如下:
     1移动表前先对表空间做整理
    SQL>alter tablespace ic_data coalesce;
     2在dba_extents找到与ID=18的数据文件相关的表及索引
    SQL>select segment_name,partition_name,segment_type
    2   from dba_extents
    3   where file_id=18;
     3对id=18的文件上的表和索引移动位置
    SQL> set heading off
    SQL> set echo off
    SQL> set feedback off
    SQL> set termout on
    SQL> spool d:\aaa.sql
    //移动表
    SQL>select DISTINCT 'alter table '|| segment_name || ' move tablespace 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 || ' move partition '|| partition_name || ' tablespace test_space;' from dba_extents where segment_type='TABLE PARTITION' and file_id=18;
    //移动分区索引
    SQL>select DISTINCT 'alter index '|| segment_name || ' rebuild partition '|| partition_name || ' tablespace test_space;' from dba_extents where segment_type='INDEX PARTITION' and file_id=18;
    SQL>spool off 
    然后执行aaa.sql,注意保证test_space有足够的空间容纳这些数据,
    其实可以不移动所有的数据,但是总的测验是不是移动了300M以外的数据,所以还是移动所有数据的方便
     4、这样移动了所有的数据以后就可以对datafile resize了

    SQL> c/9/3
      1* ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300M
    SQL> /

    数据库已更改。

     5、把原来表空间ic_data中的数据再移动回来,修改aaa.sql中的表空间名为ic_data再执行,然后drop tablespace test_space including contents and datafiles。
     
     以上操作起源于我删除了database里的一个大表造成很多空间浪费,想回收空间:)
    -----------------------分割线-----------------------------分割线-----------------------------分割线----------------------------
    经过实践,以上方法可以处理ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据问题。
    但是如果一个表空间被多个Oracle用户使用,在导出sql文件时要指定用户,否则在执行sql文件时会报错。




    原文地址:


    展开全文
  • 如果直接修改数据文件的大小,可能会遇到如下错误:ORA-03297:文件包含在请求的RESIZE值以外使用的数据SQL> ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300m;ALTER DATABASE DATA.....

    Oracle数据文件在有数据的情况下能自动扩展,却不能自动收缩,造成存储空间的浪费。如果直接修改数据文件的大小,可能会遇到如下错误: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 值以外使用的数据

    但是

    SQL>select d.filename,d.file_id,d.bytes/1024/1024 as d_byte,sum(f.bytes/1024/1024) as free_byte

    2   from dba_data_files d,dba_free_space f

    3   where d.file_id=f.file_id and d.file_id=18

    4   group by d.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空间,但是却不能resize datafile.

    为此,要改小数据文件,我们先要对文件上的表和索引移动一下位置,具体做法如下:

    1、移动表前先对表空间做整理

    SQL>alter tablespace ic_data coalesce;

    2、在dba_extents找到与ID=18的数据文件相关的表及索引

    SQL>select segment_name,partition_name,segment_type

    2   from dba_extents

    3   where file_id=18;

    3、对id=18的文件上的表和索引移动位置

    SQL> set heading off

    SQL> set echo off

    SQL> set feedback off

    SQL> set termout on

    SQL> spool d:\aaa.sql

    //移动表

    SQL>select DISTINCT 'alter table '|| segment_name || ' move tablespace 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 || ' move partition '|| partition_name || ' tablespace test_space;' from dba_extents where segment_type='TABLE PARTITION' and file_id=18;

    //移动分区索引

    SQL>select DISTINCT 'alter index '|| segment_name || ' rebuild partition '|| partition_name || ' tablespace test_space;' from dba_extents where segment_type='INDEX PARTITION' and file_id=18;

    SQL>spool off

    然后执行aaa.sql,注意保证test_space有足够的空间容纳这些数据,

    其实可以不移动所有的数据,但是总的测验是不是移动了300M以外的数据,所以还是移动所有数据的方便

    4、这样移动了所有的数据以后就可以对datafile resize了

    SQL> c/9/3

    1* ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300M

    SQL> /

    数据库已更改。

    5、把原来表空间ic_data中的数据再移动回来,修改aaa.sql中的表空间名为ic_data再执行,然后drop tablespace test_space including contents and datafiles。

    以上操作起源于我删除了database里的一个大表造成很多空间浪费,想回收空间:)

    -----------------------分割线-----------------------------分割线-----------------------------分割线----------------------------

    经过实践,以上方法可以处理ORA-03297:文件包含在请求的RESIZE值以外使用的数据问题。

    但是如果一个表空间被多个Oracle用户使用,在导出sql文件时要指定用户,否则在执行sql文件时会报错

    展开全文
  • ora-03297:文件包含在请求的RESIZE值以外使用的数据; 长期使用ORACLE 导入数据库的时候,空间默认为USER的时候,你的USERS01.DBF 会占用很多空间,而且占用率都很低,但是占用磁盘空间却很大。 所以很多人想要...
  • 为了图方便,sys用户下建立了一张大表,插入数据大概几亿条,导致system空间增长了30G左右,后面想删除数据,缩小system空间,因此truncate table,后面又drop table,但是此时只是降低了段高水位,数据文件还有...
  • 电脑空间不够用了,发现本机表空间数据文件有点儿大,想缩减下,看了下使用率,10G普通表空间用了500M,6Guser表空间用了50M, 于是查询: alter database datafile 'D:\ORACLE\ORADATA\ORCL\test01.DBF' ...
  • 增加了一个SXSJ1的数据文件,但是增加时直接给的文件大小是30G,过于占用空间,要修改为10G,但是在数据库中执行修改语句报一下错误:Failed to commit: ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据方法/...
  • 增加了一个SXSJ1的数据文件,但是增加时直接给的文件大小是30G,过于占用空间,要修改为10G,但是在数据库中执行修改语句报一下错误:Failed to commit: ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据方法/...
  • 报错:出现ora-03297错误,提示:文件包含在请求的resize值以外表分散各个数据文件存储, datafile 中使用的数据块号范围内都不能缩小,即使first block和last block 之间有free空间 。 请参照...

空空如也

空空如也

1 2
收藏数 40
精华内容 16
关键字:

文件包含在请求的resize