精华内容
下载资源
问答
  • 电脑空间不够用了,发现本机的表空间数据文件有点儿大,想缩减下,看了下使用率,10G的普通表空间用了500M,6G的user表空间用了50M, 于是查询: alter database datafile 'D:\ORACLE\ORADATA\ORCL\test01.DBF' ...

    电脑空间不够用了,发现本机的表空间数据文件有点儿大,想缩减下,看了下使用率,10G的普通表空间用了500M,6G的user表空间用了50M,
    于是查询:

    alter database datafile 'D:\ORACLE\ORADATA\ORCL\test01.DBF' resize 512M;
    

    这条语句用在普通表空间上奏效了,但是用在user上报错了

    alter database datafile 'D:\ORACLE\ORADATA\ORCL\USERS01.DBF' resize 512M;
    

    ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据
    什么鬼?
    于是找度娘几番搜寻找到了解决方法。

    1. 查询文件对应的文件号

    select file#,name from v$datafile;
    

    找到对应file#,我的是4号文件
    (有一说移动表前先对表空间做整理:alter tablespace ic_data coalesce;)

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

    select segment_name,partition_name,segment_type from dba_extents where file_id=4;
    

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

    将需缩小表空间上的内容转移到user_test表空间中
    
    --需移动的表数据
       select DISTINCT 'alter table '|| owner||'.'||segment_name || ' move tablespace user_test;' from dba_extents where segment_type='TABLE' and file_id=4;
    	--需移动的索引数据
       select DISTINCT 'alter index '|| owner||'.'|| segment_name || ' rebuild tablespace user_test;' from dba_extents where segment_type='INDEX' and file_id=4;
       --需移动的分区表数据
       select DISTINCT 'alter table '|| owner||'.'|| segment_name || ' move partition '|| partition_name || ' tablespace user_test;' from dba_extents where segment_type='TABLE PARTITION' and file_id=4;
       --需移动的分区表索引数据
       select DISTINCT 'alter index '|| owner||'.'|| segment_name || ' rebuild partition '|| partition_name || ' tablespace user_test;' from dba_extents where segment_type='INDEX PARTITION' and file_id=4;
    

    4.执行以上查到的对应sql即可

    5.执行缩小命令,问题解决

    alter database datafile 'D:\ORACLE\ORADATA\ORCL\USERS01.DBF' resize 512M;
    

    参考:

    https://www.cnblogs.com/wenlong/archive/2011/10/22/2221025.html
    https://blog.csdn.net/u013551961/article/details/73939236

    展开全文
  • 本文中的45,对应修改数据文件大小 里面的45 1.移动表前先对表空间做整理 ...2.dba_extents找到与ID=45的数据文件相关的表及索引 select segment_name,partition_name,segment_type from dba_extents wh...

    本文中的45,对应 修改数据文件大小 里面的45

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

    alter tablespace data_cis_test coalesce;

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

    select segment_name,partition_name,segment_type from dba_extents where file_id=45;

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

    待续

     

    转载于:https://www.cnblogs.com/vipsoft/p/9517048.html

    展开全文
  • 为了图方便,sys用户下建立了一张大表,插入的数据大概几亿条,导致system空间增长了30G左右,后面想删除数据,缩小system空间,因此truncate table,后面又drop table,但是此时只是降低了段的高水位,数据文件还有...

    原文

    前些天做测试,为了图方便,在sys用户下建立了一张大表,插入的数据大概几亿条,导致system空间增长了30G左右,后面想删除数据,缩小system空间,因此truncate table,后面又drop table,但是此时只是降低了段的高水位,数据文件还有高水位,因此磁盘空间并没有被释放。

    1、先查询可以利用的空闲空间
    SQL> select sum(bytes/1024/1024/1024) from dba_free_space where tablespace_name='SYSTEM';

    SUM(BYTES/1024/1024/1024)
    -------------------------
                   31.4642944

     

    2、计算datafile可以resize收缩的空间,也就是必须剩余部分其他对象正在使用的空间
        select a.file#,a.name,a.bytes/1024/1024 CurrentMB,  
           ceil(HWM * a.block_size)/1024/1024 ResizeTo,  
           (a.bytes - HWM * a.block_size)/1024/1024 ReleaseMB,  
           'alter database datafile '''||a.name||''' resize '||  
           ceil(HWM * a.block_size/1024/1024) || 'M;' ResizeCMD  
    from v$datafile a,  
         (select file_id,max(block_id+blocks-1) HWM  
           from dba_extents where file_id in   
                  (select b.file#  From v$tablespace a ,v$datafile b  
                    where a.ts#=b.ts# and a.name='SYSTEM')
           group by file_id) b  
    where a.file# = b.file_id(+)  
    and (a.bytes - HWM *block_size)>0  
    order by 5  
    /


         FILE#
    ----------
    NAME
    ----------------------------------------------------------------------------------------------
     CURRENTMB   RESIZETO  RELEASEMB
    ---------- ---------- ----------
    RESIZECMD
    ----------------------------------------------------------------------------------------------
             1
    D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSTEM01.DBF
          1024      545.5      478.5
    alter database datafile 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSTEM01.DBF' resize 546M;


    3、直接收缩数据文件
    SQL> ALTER DATABASE DATAFILE 'D:\oracle\product\10.2.0\oradata\orcl\USERS01.DBF' RESIZE 546m;
        正常情况下这样就可以了,但是我在计算datafile可以resize收缩的空间时,发现只能收缩至30G左右,如果收缩太小,出错
    SQL> ALTER DATABASE DATAFILE 'D:\oracle\product\10.2.0\oradata\orcl\USERS01.DBF' RESIZE 10240M;
    第 1 行出现错误:
    ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据

        文件也有高水位,不是你想RESIZE到多少就多少的,有些有效数据被切掉,当然是不允许的,但是除了原来那张大表,剩余的数据不可能占用怎么大的空间,所以估计是哪个表或其他对象还占用了大量空间

     

    4、找到文件对应的文件号
    SQL> select file#,name from v$datafile;

         FILE# NAME
    ---------- --------------------------------------------------------------------------------
             1 D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSTEM01.DBF
             2 D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\UNDOTBS01.DBF
             3 D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSAUX01.DBF
             4 D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\USERS01.DBF
             5 D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\EXAMPLE01.DBF
             6 E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\XTFDB\UNIEAP.DBF
             7 E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\XTFDB\NEUDOC.DBF
             8 E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\XTFDB\ELARP.DBF
             9 E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\XTFDB\SEAS.DBF
            10 E:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\XTFDB\DLMIS.DBF

     

    5、看下找到文件中最大的块号
    SQL> select max(block_id) from dba_extents where file_id=1;
    SQL> select owner,segment_name,segment_type,tablespace_name,extent_id from dba_extents where block_id=(select max(block_id) from dba_extents);
     owner  segment_name   segment_type tablespace_name extent_id  
    ------  -------------- ------------ --------------- ---------
     SYS    C_OBJ#_INTCOL#    CLUSTER     SYSTEM            18

     

    6、主要是C_OBJ#_INTCOL#这个聚簇段占用的块的位置的太大了,接下来要先查出这个聚簇段属于某张表
    SQL> select * from dba_clu_columns where cluster_name='C_OBJ#_INTCOL#';

    OWNER                          CLUSTER_NAME                   CLU_COLUMN_NAME                TABLE_NAME                 TAB_COLUMN_NAME
    ------------------------------ ------------------------------ ------------------------------ --------------------------  ---------------
    SYS                            C_OBJ#_INTCOL#                 OBJ#                           HISTGRM$                        OBJ#

    SYS                            C_OBJ#_INTCOL#                 INTCOL#                        HISTGRM$                        INTCOL#

    可以看出来,是属于HISTGRM$表,HISTGRM$系统表,这个表是记录各个业务表的数据分布情况的,网络上查到其基本可以删除

     

    7、截断c_obj#_intcol#
    SQL> truncate cluster c_obj#_intcol#;truncate cluster c_obj#_intcol#       
    第 1 行出现错误:ORA-00701: 无法变更热启动数据库所需的对象

    8、截断HISTGRM$表
    SQL> truncate table HISTGRM$;
    ORA-14512:不能对聚集对象进行操作
    ORA-00701:无法改变热启动数据库所需的对象

     

    9、使用move
    SQL> ALTER TABLE HISTGRM$ MOVE;
    第 1 行出现错误:
    ORA-14512: 不能对聚簇对象进行操作
    一样的错误

     

       上网查:CLUSTER C_OBJ#_INTCOL#增长导致数据库的SYSTEM 表空间被大量占用,因为这个CLUSTER是一个BOOTSTRAP$对象。由于是BOOTSTRAP$对象,所以无法TRUNCATE.由于这个对象是251>56,因此不是核心BOOTSTRAP$对象,所以我们用得上EVENT 38003了。大意是修改一下event级别,然后重新启动后即可。

    10、设置EVENT参数,重启数据库
    SQL> alter system set EVENT="38003 trace name context forever, level 10"   SCOPE=SPFILE;
    系统已更改。
    SQL> shutdown immediate;
    数据库已经关闭。
    已经卸载数据库。
    ORACLE 例程已经关闭。

    SQL> startup
    ORACLE 例程已经启动。

    Total System Global Area  612368384 bytes
    Fixed Size                  1250428 bytes
    Variable Size             100666244 bytes
    Database Buffers          503316480 bytes
    Redo Buffers                7135232 bytes
    数据库装载完毕。
    数据库已经打开。

     

    11、重新截断cluster c_obj#_intcol#
    SQL> truncate cluster c_obj#_intcol#;
    簇已截断。

     

    12、Resize datafile
    SQL> alter database datafile 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSTEM01.DBF' resize 548M;

    数据库已更改。

     

    13、测试,确保没有影响
    SQL> exec DBMS_STATS.GATHER_TABLE_STATS(ownname=>'scott', tabname=>'emp', estimate_percent=>30, method_opt=>'for all indexed columns size skewonly',cascade=>true, degree=>2);
    PL/SQL 过程已成功完成。

     

    14、检查使用exp与expdp是否可以顺利导出数据
    我的exp出现如下错误:
    C:\Documents and Settings\Administrator>exp scott/tiger file=e:/ymhtest.dmp

    EXP-00008: 遇到 ORACLE 错误 600
    ORA-00600: 内部错误代码, 参数: [19004], [], [], [], [], [], [],
    . . 正在导出表                           BONUS
    EXP-00008: 遇到 ORACLE 错误 600
    ORA-00600: 内部错误代码, 参数: [19004], [], [], [], [], [], [],
    . . 正在导出表                          COMMIT
    EXP-00008: 遇到 ORACLE 错误 600
    ORA-00600: 内部错误代码, 参数: [19004], [], [], [], [], [], [],
    . . 正在导出表                            DEPT
    EXP-00008: 遇到 ORACLE 错误 600
    ORA-00600: 内部错误代码, 参数: [19004], [], [], [], [], [], [],
    . . 正在导出

    我的expdp出现如下错误:
    ORA-39002: 操作无效
    ORA-39070: 无法打开日志文件。
    ORA-29283: 文件操作无效
    ORA-06512: 在 "SYS.UTL_FILE", line 475
    ORA-29283: 文件操作无效

       试过很多办法,最终还是无法解决,我的是oracle10.2.0。1的,有人说要打补丁才行,没试过,最后只好还原数据库,所以,要尽量小心。
        注意:这是不被支持的方法,建议在生产库中不要轻易实施,如果要实施
    1、备份数据库
    2、最好操作后要对重要的表进行一次分析,可能影响系统中的一些SQL的执行计划。


    展开全文
  • 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/

    展开全文
  • 为了图方便,sys用户下建立了一张大表,插入的数据大概几亿条,导致system空间增长了30G左右,后面想删除数据,缩小system空间,因此truncate table,后面又drop table,但是此时只是降低了段的高水位,数据文件还有...
  • SQL> ALTER DATABASE DATAFILE'D:\ORACLE\ORADATA\ICAPP\IC_DATA6...ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA'RESIZE 300m*ERROR 位于第 1 行:ORA-03297: 文件包含在请求RESIZE 值以外...
  • 项目组同事进行海量数据的POC实验,结果发现数据文件增长过快,超过了规划范围。笔者数据清空之后,要进行文件缩小操作,释放掉占用的空间。1、故障现象首先,我们将数据文件大小约为4G,是自动拓展后的结果。...
  • SQL> ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6....ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300m*ERROR 位于第 1 行:ORA-03297: 文件包含在请求RESIZE 值...
  • 公司客户要求系统中打印标签,标签中含有条形码、二维码,二维码中还含有GS,RS,EOT这种特殊字符,小白第一次遇见直接当字符串处理了,打印用的是一款叫Stimulsoft Reports插件,这个插件支持网页上打印,感觉...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 13,971
精华内容 5,588
关键字:

文件包含在请求的resize