oracle表空间的释放

1.shrink space

优点:降低高水位时索引不会失效

缺点:不能将表移动到其他表空间;高水位降低效果没有move明显;同时在执行命令前要先执行(alter table table_name enable row movement允许行移动)也会表会产生行级锁…,shrink比move更耗费cpu,产生很多current block这样生成巨大的redo与undo 如果表中索引很少可以建议使用move降低高水位

SQL:
alter table cbsd_log_t enable row movement;
alter table cbsd_log_t shrink space


可能会报错ORA-10631: SHRINK clause should not be specified for this object
因为:
Shrink 操作需满足表空间是本地管理和自动段空间管理(10g、11g默认就是这样),以下情况不能用shrink:
IOT索引组织表
用rowid创建的物化视图的基表
带有函数索引的表
SECUREFILE 大对象
压缩表


相比alter table move,Shrink的进步是:
1.可在线执行
2.可使用参数cascade,同时收缩表上的索引
3.执行后不会导致索引失效
4.可避免alter table move执行过程中占用很多变空间(如果表10G大小,那alter table move差不多还得需要10G空间才能执行)。


2、 move (降低高水位)

优点:可以移动表到其他表空间,在执行命令时不需要执行alter table table_name enable row movement

缺点:表move 会导致表中的索引失效,要rebuild;同时表会产生行级锁…;在此如果表中有LOB字段 时要用一下命令来实现表空间移动:alter table owner.table_name move tablespace tablespace_name lob (lob_column) store as lob segment tablespace tablespace_name;也可以单独move lob,index要rebuild


第一步:ALTER TABLE ZZWK_ZZW_TODO MOVE TABLESPACE TS_SGY_ZZKDATA LOB(INFO_BODY) STORE AS (TABLESPACE TS_SGY_ZZKDATA);
第二步:重建索引
ALTER INDEX PK_ZZWK_ZZW_TODO REBUILD TABLESPACE TS_SGY_ZZKDATA;

你可能感兴趣的:(oracle表空间的释放)