Oracle调整表空间大小resize
发布时间:2020-12-12 14:08:14 所属栏目:百科 来源:网络整理
导读:转载至:https://www.cnblogs.com/wenlong/archive/2011/10/22/2221025.html 将备份的一个大数据库还原到本机以后,删除里面的大表(比如文件表、日志表等),Oracle数据文件在有数据的情况下能自动扩展,却不能自动收缩,造成存储空间的浪费。 如果直接修改
转载至:https://www.cnblogs.com/wenlong/archive/2011/10/22/2221025.html将备份的一个大数据库还原到本机以后,删除里面的大表(比如文件表、日志表等),Oracle数据文件在有数据的情况下能自动扩展,却不能自动收缩,造成存储空间的浪费。 转载网址:http://blog.sina.com.cn/s/blog_54eeb5d901000bvg.html SQL> ALTER DATABASE DATAFILE 'D:ORACLEORADATAICAPPIC_DATA6.ORA' RESIZE 300m;ALTER DATABASE DATAFILE 'D:ORACLEORADATAICAPPIC_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.bytes/1024/1024; FILE_NAME FILE_IDD_BYTE FREE_BYTE --------------------------------- ---------- ---------- ---------- D:ORACLEORADATAICAPPIC_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 'alterindex '|| 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 'alterindex '|| 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 数据库已更改。 5、把原来表空间ic_data中的数据再移动回来,修改aaa.sql中的表空间名为ic_data再执行,然后drop tablespace test_space including contents and datafiles。 以上操作起源于我删除了database里的一个大表造成很多空间浪费,想回收空间:) -----------------------分割线-----------------------------分割线-----------------------------分割线---------------------------- 经过实践,以上方法可以处理 ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据问题。 但是如果一个表空间被多个Oracle用户使用,在导出sql文件时要指定用户,否则在执行sql文件时会报错(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- c# – 为什么Interlocked.CompareExchange仅支持引用类型?
- react-native – React Native ListView – rowHasChanged不
- SQL与NoSQL的融合架构产品:GBase UP
- 从Dojo1.6到Dojo1.8(三)—— Parser,Dijit,DojoX
- ruby-on-rails – 在rails中设置一个带有独角兽,nginx和cap
- 正则表达式(一)
- ajax在兼容模式下失效的快速解决方法
- 使用 Electron 调用基本或附带图像的通知
- ruby-on-rails-3 – 在Rails 3中,使用Formtastic 2,如何用d
- (23)ajax实现上传文件的功能