oracle不能缩小表空间,更改oracle的表空间,特别是缩小时的问题 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 值以外使用的数据

但是

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里的一个大表造成很多空间浪费,想回收空间:)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值