oracle resize什么意思,Oracle调整表空间大小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 值以外使用的數(shù)據(jù)
但是
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
可以看到實(shí)際上ID=18的文件只使用了大概50M左右,只是數(shù)據(jù)分布在(按一定的順序)50M甚至在300M以外的地方,所以這里雖然看到只使用了約50M空間,但是卻不能resize datafile.
為此,要改小數(shù)據(jù)文件,我們先要對文件上的表和索引移動(dòng)一下位置,具體做法如下:
1、移動(dòng)表前先對表空間做整理
SQL>alter tablespace ic_data coalesce;
2、
在dba_extents找到與ID=18的數(shù)據(jù)文件相關(guān)的表及索引
SQL>select segment_name,partition_name,segment_type
2?? from dba_extents
3?? where file_id=18;
3、
對id=18的文件上的表和索引移動(dòng)位置
SQL> set heading off
SQL> set echo off
SQL> set feedback off
SQL> set termout on
SQL> spool d:\aaa.sql
//移動(dòng)表
SQL>select DISTINCT 'alter table '|| segment_name || ' move tablespace test_space;' from dba_extents where segment_type='TABLE' and file_id=18;
//移動(dòng)索引
SQL>select DISTINCT 'alter?index '|| segment_name || '?rebuild tablespace test_space;' from dba_extents where segment_type='INDEX' and file_id=18;
//移動(dòng)分區(qū)表
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;
//移動(dòng)分區(qū)索引
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
然后執(zhí)行aaa.sql,注意保證test_space有足夠的空間容納這些數(shù)據(jù),
其實(shí)可以不移動(dòng)所有的數(shù)據(jù),但是總的測驗(yàn)是不是移動(dòng)了300M以外的數(shù)據(jù),所以還是移動(dòng)所有數(shù)據(jù)的方便
4、這樣移動(dòng)了所有的數(shù)據(jù)以后就可以對datafile resize了
SQL> c/9/3
1* ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300M
SQL> /
數(shù)據(jù)庫已更改。
5、把原來表空間ic_data中的數(shù)據(jù)再移動(dòng)回來,修改aaa.sql中的表空間名為ic_data再執(zhí)行,然后drop tablespace test_space including contents and datafiles。
以上操作起源于我刪除了database里的一個(gè)大表造成很多空間浪費(fèi),想回收空間:)
-----------------------分割線-----------------------------分割線-----------------------------分割線----------------------------
經(jīng)過實(shí)踐,以上方法可以處理
ORA-03297: 文件包含在請求的 RESIZE 值以外使用的數(shù)據(jù)問題。
但是如果一個(gè)表空間被多個(gè)Oracle用戶使用,在導(dǎo)出sql文件時(shí)要指定用戶,否則在執(zhí)行sql文件時(shí)會(huì)報(bào)錯(cuò)
總結(jié)
以上是生活随笔為你收集整理的oracle resize什么意思,Oracle调整表空间大小resize的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: long转string mybatis_
- 下一篇: JAVA中数字格式异常,java - J