-- 收缩表段(shrink space)
--====================
一、表的增长方式
当表被创建后,随着记录的不断插入,组成表的区间会被填满,如果启用了自动扩展,则当区间填满后,会分配新的区间。假定高水
位线随着记录的增加从最左端往右端来移动,当到底部区间的尾端时,则新的区间将会被分配。
二、表可收缩的原理
随着记录的增加高水位线不断的右移,记录的删除不会导致高水位线往回(左)移动
删除记录后的空闲空间(高水位线左侧)尽管可以使用,但其稀疏性导致空间空闲
注:完整的表扫描所耗费的时间不会因为记录的减少(删除)而减少
三、使用 alter table tbname shrink space 来收缩表段
1. 实现原理
实质上构造一个新表(在内部表现为一系列的DML操作,即将副本插入新位置,删除原来位置的记录)
靠近末尾处(右端)数据块中的记录往开始处(左端)的空闲空间处移动(DML操作),不会引起DML触发器
当所有可能的移动被完成,高水位线将会往左端移动(DDL操作)
新的高水位线右边的空闲空间被释放(DDL操作)
2. 实现前提条件
必须启用行记录转移(enable row movement)
仅仅适用于堆表,且位于自动段空间管理的表空间(堆表包括:标准表,分区表,物化视图容器,物化视图日志表)
3. 不能实现收缩的表
群集表
具有LONG类型列的表
LOB段(尽管表本身可以被缩小),注,10gR2以后版本支持对LOB段的收缩
具有基于提交的物化视图的表(因为禁用了触发器)
具有rowid物化视图的表(因为rowid发生了变化)
IOT映射表IOT溢出段
索引基于函数的表
未启用行记录转移的堆表
4. 段收缩的优点
提高缓存利用率,提高OLTP的性能
减少磁盘I/O,提高访问速度,节省磁盘空间
段收缩是在线的,索引在段收缩期间维护,不要求额外的磁盘空间
5. 两个选项
cascade:缩小表及其索引,并移动高水位线,释放空间
compact:仅仅是缩小表和索引,并不移动高水位线,不释放空间
alter table tbname shrink space 相当于带cascade参数
四、实战演习
1. 查看需要收缩的表段的基本情况,此处为表big_table
2. 删除记录之后,进行收缩表段
3. 验证cascade与compact的差异
五、语法总结:
六、批量收缩脚本
1. 普通表(根据相应需求修改下面的语句生产相应脚本)
2. 分区表的处理
分区表进行shrink space时发生ORA-10631错误.shrink space有一些限制.
在表上建有函数索引(包括全文索引)会失败。
3. 附show_space脚本(来自Tom大师)
七、快捷参考
有关性能优化请参考
有关ORACLE体系结构请参考
Oracle联机重做日志文件(ONLINE LOG FILE)
Oracle实例和Oracle数据库(Oracle体系结构)
有关闪回特性请参考
Oracle闪回特性(FLASHBACK DATABASE)
Oracle闪回特性(FLASHBACK DROP & RECYCLEBIN)
Oracle闪回特性(Flashback Query、FlashbackTable)
Oracle闪回特性(Flashback Version、Flashback Transaction)
有关基于用户管理的备份和备份恢复的概念请参考
Oracle基于用户管理恢复的处理 (详细描述了介质恢复及其处理)
有关RMAN的备份恢复与管理请参考
RMAN 备份路径困惑(使用plus archivelog时)
有关ORACLE故障请参考
对参数FAST_START_MTTR_TARGET= 0 的误解及设定
有关ASM请参考
有关SQL/PLSQL请参考
SQL 基础 --> 集合运算(UNION与UNION ALL)
SQL 基础 --> 层次化查询(STARTBY ... CONNECT BY PRIOR)
SQL 基础 --> ROLLUP与CUBE运算符实现数据汇总
有关ORACLE其它特性
使用OEM,SQL*Plus,iSQL*Plus 管理Oracle实例
日志记录模式(LOGGING、FORCE LOGGING 、NOLOGGING)
使用外部表管理Oracle 告警日志(ALAERT_$SID.LOG)
簇表及簇表管理(Index clustered tables)
ORACLE_SID、DB_NAME、INSTANCE_NAME、DB_DOMIAN、GLOBAL_NAME
Oracle补丁全集 (Oracle 9i 10g 11g Path)