表压缩是若何工做的在Orcle9i第2版中,表压缩特征通过删除在数据库表中发现的反复数据值来节省空间。压缩是在数据库的数据块级别长进行的。当确定一个表要被压缩后,数据库便在每一个数据库数据块中保留空间,以便贮存在该数据块中的多个位置上呈现的数据的单一拷贝。
那一被保留的空间被称做符号表(symbol table)。被标识为要停止压缩的数据只存储在该符号表中,而不是在数据库行自己内。当在一个数据库行中呈现被标识为要压缩的数据时,该行在该符号表中存储一个指向相关数据的指针,而不是数据自己。节约空间是通过删除表中数据值的冗余拷贝而实现的。
1。表级别1。1创建一个压缩表:创建表时利用COMPRESS关键字,COMPRESS关键字指示Oracle数据库尽可能以压缩的格局存储该表中的行。
create table test compress as select * from dba_objects where 1=2;create table test (id number,name varchar2(20),time date) compress;1。
2修改现有表为压缩表:SQL> alter table test compress;打消表的压缩:SQL> alter table test nocompress;1。3确定表能否被压缩:确定一个表能否利用了压缩,查询user_tables,compression字段表白表能否被压缩
2。
表空间级别2。1创建表压缩空间create tablespace TEST datafile '/export/home/oracle/ora10g/oradata/test/test。dbf' size 10M default compress;与其他存储参数类似,COMPRESS属性也具有一些继承特征。
当在一个表空间中创建一个表时,它从该表空间继承COMPRESS属性。
2。2。使现有表空间转换为压缩表空间SQL> alter tablespace test default compress;SQL> alter tablespace test default nocompress;2。
3。确定能否已经操纵compress对一个表空间停止了定义,可查询user_tablespaces数据字典视图并查看def_tab_compression列SQL> select tablespace_name,def_tab_compression from user_tablespaces;
3。
压缩一个已经存在但并没有压缩的表利用alter table …… move compress使一个已存在但未压缩的表转换为压缩表。
SQL> alter table test move compress;同样,也能够利用alter table…… move nocompress来解压一个已经压缩的表:SQL> alter table test move nocompress;4。
压缩表的性能开销一个压缩的表能够存储在更少的数据块中,从而节省了贮存空间,而利用更少的数据块也意味着性能的进步。 在一个I/O遭到必然限造的情况中对一个压缩的表停止查询凡是能够更快速地完成,因为他们需要阅读的数据库数据块要少得多。
1008680数据压缩比例:
1008680数据插入消耗的时间:
由此能够看出,向压缩表中参加数据的时间是一般表的3倍多。
加载压缩的表所需要的额外时间来自于在数据加载过程中所施行的压缩操做。
能够得出的结论是:在很少改动的表上利用压缩手艺仍是能够的。表中数据经常变更的情况下,尽量不要利用表压缩,它影响插入操做。