Oracle索引3--索引键压缩
发布时间:2020-12-12 15:18:07 所属栏目:百科 来源:网络整理
导读:Oracle索引3--索引键压缩 索引键压缩的是可以减小索引的大小,从而减少IO量,使扫描索引时效率更高,压缩的条件是索引的前导列或者前几个索引字段是有重复的(当然这个索引肯定是多键值索引)。比如我在这篇博客中创建的索引:http://blog.csdn.net/chuan_day/
Oracle索引3--索引键压缩索引键压缩的是可以减小索引的大小,从而减少IO量,使扫描索引时效率更高,压缩的条件是索引的前导列或者前几个索引字段是有重复的(当然这个索引肯定是多键值索引)。比如我在这篇博客中创建的索引:http://blog.csdn.net/chuan_day/article/details/60606480。在记录行数比较大的情况下,索引键压缩是提高SQL语句性能的很有效的手段。 下面通过例子来实现对比: 创建表t11:create table t11 as select * from dba_objects; 创建索引:create index t11_idx on t11(owner,object_type,object_name);这里owner的重复很高因为比较数据库中用户数不会很多,对象类型也不会很多,而对象名称那就基本上不会一致 。 在这篇博客中我已经解释了如何使用index_stats视图,解释了几个比较重要的字段:http://blog.csdn.net/chuan_day/article/details/60606480 通过以下几个例子可以很清晰的看到索引键压缩减少的空间量,其实也就是访问索引时IO的减少。 1、不压缩的情况下,记录在idx_stats表中 analyze index T11_IDX validate structure; create table idx_stats as select 'nocompressed' compress_, height, lf_blks, t.br_blks, t.btree_space, t.opt_cmpr_count, t.opt_cmpr_pctsave from index_stats t; 2、压缩第一个字段 drop index t11_idx; create index t11_idx on t11(OWNER,OBJECT_TYPE,OBJECT_NAME) compress 1; analyze index T11_IDX validate structure; insert into idx_stats select 'compressed 1' compress_, t.opt_cmpr_pctsave from index_stats t; 3、压缩前两个字段 drop index t11_idx; create index t11_idx on t11(OWNER,OBJECT_NAME) compress 2; analyze index T11_IDX validate structure; insert into idx_stats select 'compressed 2' compress_, t.opt_cmpr_pctsave from index_stats t; 4、压缩三个字段 drop index t11_idx; create index t11_idx on t11(OWNER,OBJECT_NAME) compress 3; analyze index T11_IDX validate structure; insert into idx_stats select 'compressed 3' compress_, t.opt_cmpr_pctsave from index_stats t; 5、查看idx_stats表 SQL> select * from idx_stats; COMPRESS_ HEIGHT LF_BLKS BR_BLKS BTREE_SPACE OPT_CMPR_COUNT OPT_CMPR_PCTSAVE ------------ ---------- ---------- ---------- ----------- -------------- ---------------- nocompressed 3 591 4 4760128 2 28 compressed 1 3 524 4 4222032 2 19 compressed 2 3 422 3 3398408 2 0 compressed 3 3 662 4 5325480 2 35 结果很明显了在不压缩的情况下索引在b-tree中是4760128,OPT_CMPR_COUNT=2是Oracle建议使用compress 2压缩 ,OPT_CMPR_PCTSAVE的值是Oracle建议使用conpress=2压缩后能节约空间的百分比例。 四条数据很明显能得出结论compress=2时索引时最节约空间的,压缩3个字段时反而更大了,因为object_name字段时基本不重复的所以Oracle无法压缩这个索引,这其实没有节约空间的,多出的空间是压缩时需要4个字节的成本,因此反而更大了。 使用analyze index T11_IDX validate structure能判断是否压缩索引,是比较有用的调优手段,IO的开销往往是SQL语句性能的瓶颈,因此能省多少就省多少,至少我是这么干的。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |