站长家园(原代码之家)(www.adminjie.com)网站源码,微信源码,游戏源码,商业源码分享平台。
当前位置:网站首页 技术文章 网络编程 正文

oracle索引反转是什么

时间:2022-06-13 [网络编程]作者:fabuyuan 浏览:3 次

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

本教程操作环境:windows10系统、Oracle 12c版、Dell G3电脑。

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视频教程

以上就是oracle索引反转是什么的详细内容,更多请关注站长家园其它相关文章!

本文标签:  oracle

转载请注明来源:oracle索引反转是什么

本文永久链接地址:https://www.adminjie.com/post/13428.html

免责声明:
本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。

附:
二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!

版权声明:
一、本站致力于为软件爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的部分源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、我站提供用户下载的所有内容均转自互联网。如有内容侵犯您的版权或其他利益的,若有侵犯你的权益请:提交版权证明文件到邮箱 2225329873#qq.com(#换为@) 站长会进行审查之后,情况属实的会在三个工作日内为您删除。

  • 站长家园(原代码之家)会员升级
  • 最新文章
    • php怎么去除二维数组中的第一个子数组

      php怎么去除二维数组中的第一个子数组

      去除方法:1、用foreach遍历二维数组的外层数组元素,语法“foreach($arras$k=>$v){//循环体}”;2、在循环体,使用is_a...

    • html5中web储存的含义是什么

      html5中web储存的含义是什么

      html5中web储存的含义是让网页在用户计算机上保存一些信息,使用HTML5可以在本地存储用户的浏览数据;web储存又可以分为本地存储和会话存储,分别对应lo...

    • html5的注释有快捷键吗

      html5的注释有快捷键吗

      html5的注释有快捷键;可以利用“ctrl+/”快捷键实现注释,选中需要注释的代码后,利用该快捷键就会在指定代码前添加“<!--”,在指定代码后添加“-...

    • mysql索引的查询语句是什么

      mysql索引的查询语句是什么

      mysql索引的查询语句是“SHOWINDEX”,可以返回与当前数据库或指定数据库中的表关联的索引信息,完整语法“SHOWINDEXFROM表名[FR...

    • html5里面的data属性的作用是什么

      html5里面的data属性的作用是什么

      html5里面的data属性的作用是存储私有页面后应用的自定义数据,“data-*”是HTML5新增的一个自定义数据属性功能,作为可以暂存数据使用,自定义的数据...

    热门文章