应用背景:
某些情况下,由于前期设计上没有考虑全面,导致表空间预建太大,远远超出实际使用大小。于是,就出现了收缩表空间这样的需求,即将这个表空间的占用空间进行收缩。
处理方案:
对于表空间收缩,Oracle只提供扩大的功能,而不提供收缩。所以,要实现这样的要求,就只能先创建一个中间表空间,然后将待收缩表空间中的数据迁移到这个表空间下
处理方法:
1、找出该表空间下的所有数据对象;
select segment_type, partition_name, segment_name from dba_segments;
2、创建目标空间(不强制创建,但是建议)。
create tablespace dbs_temp datafile 'd:\dbs_temp01.dbf' size 100m;
3、根据对象类型重建或转移对应数据;
对于
table:
alter table xx move tablespace dbs_temp;
对于partition table:
alter table xx move partition xx1 tablespace dbs_temp;
对于
index:
alter index ixx rebuild tablespace dbs_temp;
对于lob字段:
alter table xx move lob(col_name) store as (tablespace dbs_temp);
一般情况下,下面语句基本可以涵盖所有的数据对象了:
select segment_type, segment_name, partition_name,
case segment_type
when 'TABLE' then 'alter table ' || owner || '.' || segment_name || ' move tablespace dbs_temp;',
when 'INDEX' then 'alter index ' || owner || '.' || segment_name || ' rebuild tablespace dbs_temp;',
when 'INDEX PARTITION' then 'alter index ' || owner || '.' || segment_name || ' rebuild tablespace dbs_temp;',
when 'TABLE PARTITION' then 'alter table ' || owner || '.' || segment_name || ' move partition ' || partition_name || 'tablespace dbs_temp;' sqltext
from dba_segments
where tablespace_name = 'FUND_TABLE'
and segment_type not like 'LOB%';
下面是迁移lob字段的
select table_name, column_name, 'alter table ' || owner || '.' || table_name || ' move lob(' || column_name || ') store as(tablespace dbs_temp);' sqltext
from dba_lobs
where tablespace_name = 'FUND_TABLE';
4、删除清空后的表空间;
drop tablespace dbs_old including contents and datafiles;
下面步骤简单了,就不一一列举。
5、如果对表空间名称有要求,则使用原来的表空间名再次创建一个合适大小的表空间。
6、将目标表空间中的数据再迁移回新建的最终的表空间。
分享到:
相关推荐
描述了Oracle数据下如何对一个比较大的表空间进行收储。
数据库备份恢复时,获取oracle表空间脚本,创建用户等
oracle表空间信息,查看Oracle表空间空闲与已用大小
表空间:是一个或多个数据文件的逻辑集合 表空间逻辑存储对象:永久段-->如表与索引 临时段-->如临时表数据与排序段 回滚段-->用于事物回滚或闪回内存的撤销数据 表空间分类:系统表空间(system、sysaux),...
Oracle表空间Oracle表空间Oracle表空间Oracle表空间Oracle表空间
演示如何收缩Oracle数据库的undo表空间
oracle 收缩undo表空间,需要收缩Undo表空间时特别有用。
oracle表空间创建
该文档详细描述了oracle表空间已满后如何查询表空间占用情况,如何扩展表空间。
利用DBMS_SPACE包对Oracle 表碎片进行监控与清理,
Oracle 表空间建立方法
六分钟学会创建Oracle表空间的步骤[转]
详细介绍如何正常删除Oracle 数据库表空间数据文件,OFFLINE和OFFLINE DROP的区别,OS级别删除了数据文件后的恢复,删除数据库表空间数据文件演示示例
针对oracle表空间收缩的操作!请仔细查看内部的说明。对于表空间过于庞大的数据库能起到回收剩余空间,并降低高水位HWM的作用
oracle创建一个表空间创建临时表空间创建用户表空间资源的权限
一、查看Oracle数据库中表空间信息的方法 1、查看Oracle数据库中表空间信息的工具方法 2、查看Oracle数据库中表空间信息的命令方法 二、查询Oracle数据库中数据文件信息的方法 1、查看Oracle数据库中数据文件信息的...
oracle表空间详解
oracle表空间命令语句大全,关于表空间的讲解及关于表空间操作命令的语句。
oracle表空间不足报错的解决 。。。。。。。。。。。。。。。。。。。。。。
Oracle创建临时表空间、表空间的创建代码