oracle 存储数据库如果要存储较长一段时间的数据,空间经常不够用,这时就要充分利用oracle 表压缩节机制。
1创建一个压缩的表
create table table_name()compress;
修改成压缩表
alter table table_name compress;
以上压缩表并没有压缩数据,如果要达到预期效果,插入数据时候要加/*+append*/
insert/*+append*/ into table_name select * from table_name2;
2一次性创建压缩表
create table table_name compress as select * from table_name2;
3如果有一个表未被压缩,现在要改成压缩表(已经有数据的情况下)
alter table table_name move compress;
4压缩一个已经分区的表
alter table table_name move partition part_name compress;
注:当删除一个压缩的表中的一行时,数据库将释放该行在数据库数据块中所占据的空间。 这一自由空间可以由未来插入的数据重新使用。但是,由于以惯用模式插入的行不能被压缩,所以它不太可能适合放在一个被压缩的行所释放的空间。大量的相继的DELETE与INSERT语句可能会导致磁盘碎片,且所浪费的空间甚至会多于使用压缩所能节省的空间。
所以压缩表 比较适用于只读表、对于经常需要删除修改数据的不太合适。
[@more@]来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9307930/viewspace-1026602/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/9307930/viewspace-1026602/