您的位置: 翼速应用 > 业内知识 > 数据库 > 正文

关于oracle索引反转的详细解析

本文是关于oracle索引反转的详细解析,索引翻转指的是在创建索引时,针对索引列的索引键值进行字节反转,进而实现分散存放不同子节点块的目的,是“B-tree”索引的一个分支;使用反向索引,能将索引列的键值进行反转,实现顺序的键值分散到不同的叶块中,从而减少索引块的争用。


关于oracle索引反转的详细解析



关于oracle索引反转的详细解析


反向索引作为B-tree索引的⼀个分⽀,主要是在创建索引时,针对索引列的索引键值进⾏字节反转,进⽽实现分散存放到不同叶⼦节点块的⽬的。


反向索引针对的问题


使⽤传统的B-tree索引,当索引的列是按顺序产⽣时,相应的索引键值会基本分布在同⼀个叶块中。当⽤户对该列进⾏操作时,


难免会发⽣索引块的争⽤。


使⽤反向索引,将索引列的键值进⾏反转,实现顺序的键值分散到不同的叶块中,从⽽减少索引块的争⽤。


例如:键值1001、1002、1003,反转后1001、2001、3001,进⽽分散到不⽤的叶⼦节点块中。


当载入一些有序数据时,索引肯定会碰到与I/O相关的一些瓶颈。在数据载入期间,某部分索引和磁盘肯定会比其他部分使用频繁得多。为了解决这个问题,可以把索引表空间存放在能够把文件物理分割在多个磁盘上的磁盘体系结构上。


为了解决这个问题,Oracle还提供了一种反转键索引的方法。如果数据以反转键索引存储,这些数据的值就会与原先存储的数值相反。这样,数据1234、1235和1236就被存储成4321、5321和6321。结果就是索引会为每次新插入的行更新不同的索引块。


不能对位图索引和索引组织表进行反转键处理。


技巧:


如果您的磁盘容量有限,同时还要执行大量的有序载入,就可以使用反转键索引。


不可以将反转键索引与位图索引或索引组织表结合使用。


ORACLE DBA实践:创建反转关键字索引


对于大型联机事务处理系统来说,其中的表一般都很大,在这些表的主键是由序列号产生的,而且上面是有索引的。因此相邻的索引记录就可能存在同一个数据块中,这样会形成数据块的竞争。而随着时间流逝,会不断在这些表中删除旧的无用的数据,插入新的有用的数据,很显然删除的数据是序列号很小的旧数据,而插入的数据序列号是刚刚产生的(一定是大号),这就造成了另一个严重的问题:即该索引的树是往序列号大的一面偏,因此会使得树的深度加深从而使系统效率下降。


为了解决上述问题,oracle引入了反转关键字索引。反转关键字索引通过将关键字(序列号)的每个字节顺序颠倒过来再建索引的方法实现的。原来相邻的order#经反转之后就不再相邻了,这样就可以把相邻的order#分散到不同的数据块中,上述问题也就迎刃而解。


但反转索引关键字也存在问题。例如在反转关键字索引的表上进行范围查询就会遇到麻烦。在正常索引的况下,满足条件的索引记录应该放在同一个或相邻的数据块中,速度会很快;而使用反转关键字索引之后,原来相邻的满足条件的索引记录已经被分散到多个数据块中,此事要完成查询操作只能进行全表扫描。因此在决定是否使用反转关键字索引时,要分清是插入操作重要,还是范围查询重要。


关于oracle索引反转的详细解析就到这里,翼速应用平台内有更多相关资讯,欢迎查阅!


我来说两句

0 条评论

推荐阅读

  • 响应式布局CSS媒体查询设备像素比介绍

    构建响应式网站布局最常见的是流体网格,灵活调整大小的站点布局技术,确保用户在使用的幕上获得完整的体验。响应式设计如何展示富媒体图像,可以通过以下几种方法。

    admin
  • 提升网站的性能快速加载的实用技巧

    网站速度很重要,快速加载的网站会带来更好的用户体验、更高的转化率、更多的参与度,而且在搜索引擎排名中也扮演重要角色,做SEO,网站硬件是起跑线,如果输在了起跑线,又怎么跟同行竞争。有许多方法可提升网站的性能,有一些技巧可以避免踩坑。

    admin
  • 织梦CMS TAG页找不到标签和实现彩色标签解决方法

    织梦cms是我们常见的网站程序系统的一款,在TAG标签中常常遇到的问题也很多。当我们点击 tags.php 页的某个标签的时候,有时会提示:“系统无此标签,可 能已经移除!” 但是我们检查程序后台,以及前台显示页面。这个标签确实存在,如果解决这个问题那?

    admin
  • HTML关于fieldset标签主要的作用

    在前端开发html页面中常用的标签很多,今天为大家带来的是关于HTML中fieldset标签主要的作用说明,根据技术分析HTML

    admin

精选专题