oracle索引分类与区分,深入理解Oracle表(6):堆组织表(HOT)和索引组织表(IOT)的区别...

摘要:

堆表:又称堆组织表,常用的表类型,以堆的方式管理,当增加数据时,将使用段中第一个适合数据大小的空闲空间。当删除数据时,留下的空间允许以后的DML操作重用。 堆组织表(heap table)

应用中99%(或者更多)的情况下使用的可能都是堆组织表,不过随着IOT的出现,这种状况以后可能会有所改观,因为IOT本身就可以加索引。执行 CREATE TABLE语句时,默认得到的表类型就是堆组织表。如果你想要任何其他类型的表结构,就需要在CREATE语句本身中指定它。

堆 (heap)是计算机科学领域中得到深入研究的一种经典数据结构。它实际上就是一个很大的空间、磁盘或内存区(当然,这里所说的磁盘是指数据库表的相应磁 盘),会以一种显然随机的方式管理。数据会放在最合适的地方,而不是以某种特定顺序来放置。许多人希望能按数据放入表中的顺序从表中取出数据,但是对于 堆,这是无法保证的。这一点很容易说清楚。 参见:

oracle表类型  http://suntengjiao1.blog.163.com/blog/static/99211088200982522251123/

㈠ HOT和IOT的起源

堆组织表的存储速度因为不用考虑排序, 所以存储速度会比较快. 但是要查找符合某个条件的记录, 就必须得读取全部的记录以便筛选.

而这个时候为了加快查询速度, 索引就出现了, 索引是针对少量特定字段的值拿出来进行排序存储, 并记录在表中的位置,

而因为索引是有序的, 所以就会很容易通过索引查询到具体的记录位置, 然后再根据记录位置直接从表中读取该记录.

同时因为索引的字段较少, 所以索引通常会比其基表小得多.

从上面通过索引访问表记录的方式可以看出, 当要访问的数据量较大时, 通过每一条记录的位置去访问原始记录,

每一条符合条件的记录都需要经过索引访问后再访问基表这样一个复杂的过程, 这会花费很多时间,

同样, 如果不经过索引而直接查询表, 也可能因为表字段太多, 记录较大的情况下把全部的数据读取进来, 这也会花费很多时间.

那怎么办呢?

这个时候就会想到, 如果表中数据本身就是有序的, 这样查询表的时候就可以快速的找到符合条件的记录位置,

而很容易判断符合条件记录的位置, 这样只需要读取一小部分数据出来就可以了, 不需要全表记录都读取出来进行判断.

索引表就这样产生了.当然索引表中插入,更新资料的时候可能会因为需要排序而将数据重组, 这时候数据插入或更新速度会比堆组织表慢一些.

如果堆组织表上有索引, 那么对堆组织表的插入也会因为要修改索引而变慢

我们可以看到堆组织表+索引的方式 与 索引表 都能够实现数据的快速查找, 那为什么不全部采用索引表呢, 这样不是很简单吗?

我能想到的是前者我们可以针对不同的查找条件建立多个索引, 而后者却不行, 后者只能对某一组查询条件有效.

当然了,索引表上查询任何记录都是走索引的, 因为它本身就是索引结构.

当查询条件不符合指定条件时, 必须走 index full sacn , 需要扫描全部索引.

这就是说这时无法利用索引表已经根据某些字段排序的事实.也即排序对于这个查询来说无用.

而符合指定的条件时就会走 index range scan

㈡ 定义

① 堆组织表,其索引中记录了记录所在位置的rowid,查找的时候先找索引,然后再根据索引rowid找到块中的行数据。索引和表数据是分离的

② 索引组织表,其行数据以索引形式存放,因此找到索引,就等于找到了行数据。索引和数据是在一起的

㈢ 查找过程                ① 堆组织表                      一般索引大概3-5层,比如rowid为007,那么要找到007可能会先从第一层找<1000,再在第二层找到<100           然后在第三层找到007(注意这已经是3次I/O)           接着再通过007中标识的rowid去对应的磁盘上读取块中的行数据(第4次I/O)                ② 索引组织表                      前面的步骤同上,但是找到007后,由于数据和索引在一起,因此不必再找什么rowid,直接返回结果了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/452623.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flask爱家租房--发布新房源(总结)

重点总结 学习过程中&#xff0c;发现house_id贯穿两个接口内容&#xff0c;现对后端逻辑部分做以下总结&#xff1a; 1&#xff09;房东首先在前端填写房屋的基本信息&#xff0c;此时通过newhouse.js文件$("#form-house-info").submit(function (e) {…}进行处理&…

关系的三类完整性约束

规则2.1实体完整性规则&#xff08;Entity Integrity&#xff09;若属性A是基本关系R的主属性&#xff0c;则属性A不能取空值空值就是“不知道”或“不存在”或“无意义”的值例&#xff1a; 选修&#xff08;学号&#xff0c;课程号&#xff0c;成绩&#xff09; “学号、课…

[QNAP crontab 定時執行程式

注意要自動執行的 sh 檔不要放在 /root 裡, 不然韌體更新後檔案會不見, 要放在個人帳號的資料夾&#xff0c;例如 /share/homes/帳號/ QNAP 的 crontab 放在 /etc/config/crontabvi /etc/config/crontab 例如要每日5:00執行 backup.sh 的話&#xff0c;加上這行 00 5 * * * /s…

调整标志位方法oracle,面试题(二)(示例代码)

1.查找/us/oc al/nginx/ogs下更改时间在7天前以log 后极的文件井移动到sr/oca/nginx/log/backup下(至少两种方法)2. Centos 查看某个进程的环境安量3.简述DNS迭代查询和递归直询的区别4.简述TCP三次握手过程以及涉及到的状态(可画草图) ?5.统计TCP连接状态(至少两种方法)6.发现…

国际最具潜力IT专业认证

正如很多的争论一样&#xff0c;IT认证也是现在争论的热点&#xff0c;在IT专业人士的世界里&#xff0c;IT认证对于其职业规划有着很大的影响。在时下究竟哪个认证才具有最大意义呢&#xff1f;本文罗列了十个最具潜力的技术认证&#xff0c;一起来看看都有哪些吧&#xff01;…

关系代数

关系代数是一种抽象的查询语言&#xff0c;它用对关系的运算来表达查询关系代数运算对象是关系运算结果亦为关系关系代数的运算符有两类&#xff1a;集合运算符和专门的关系运算符

设计模式的六大原则

设计模式是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。使用设计模式是为了可重用代码、让代码更加容易被他人理解、保证代码可靠性。设计模式是代码编制真正工程化&#xff08;工程化即系统化、模块化、规范化的一个过程。指将具有一定规模数量的单个…

作业7

stuNum 201709090072 print(年级是&#xff1a;stuNum[0:4]) print(专业编号是: stuNum[4:9]) print(序号是: stuNum[-3:]) stuNum 440982201812111876 print(所在省市&#xff1a;stuNum[0:2]) print(所在地区&#xff1a;stuNum[2:4]) print(所在县区&#xff1a;stuNum[4:…

linux进程退出没有log,Linux下应用进程消失原因分析-Go语言中文社区

应用部署在Linux环境下&#xff0c;如果出现未知原因导致应用进程被杀(应用日志中没有任何异常现象&#xff0c;日志出现中断现象)&#xff0c;如果对于进程消失原因没有特别明确的方向&#xff0c;可以考虑从系统日志(/var/log/messages)方面查找原因。 命令参考egrep -i kill…

数学是成就卓越开发人员的必备技能

编者按&#xff1a;原文作者Alan Skorkin是一名软件开发人员&#xff0c;他在博客中分享对软件开发相关的心得&#xff0c;其中有很多优秀的文章&#xff0c;本文就是其中一篇&#xff0c;作者认为&#xff1a;成为优秀的开发人员&#xff0c;可以没有数学技能&#xff0c;但成…

Flask爱家租房--celery(总结)

0. celery整体逻辑图 个人理解为&#xff1a;此处的客户端client与以往定义的客户端&#xff08;前端&#xff09;并不一样&#xff0c;角色相当于以往的后端逻辑处理代码&#xff0c;即发布任务的一方&#xff0c;只是相当于处理者worker而言是客户端。 1.准备工作&#xff1…

linux端口514启动,Linux查看端口使用状态及启动(示例代码)

Netstat -tln 命令是Linux查看端口使用情况/etc/init.d/vsftp start 是用来启动ftp端口~&#xff01;看文件/etc/servicesnetstatLinux查看端口查看已经连接的服务端口(ESTABLISHED)netstat -aLinux查看端口查看所有的服务端口(LISTEN&#xff0c;ESTABLISHED)sudo netstat -ap…

window服务器开站点(不通用)

此文章为记录自己的配置流程&#xff0c;其他人不通用 网站服务器&#xff1a;Windows server 2008 R2 (IIS6.1) Asp.net 数据库服务器&#xff1a;Windows server 2008 R2 SQL Server 2008 R2 1.解析域名到服务器&#xff0c;如&#xff1a;www.test.com 2.登录网站服务器&a…

【转载】优秀文章转载集合

Spring Spring Cache 注释驱动的 Spring cache 缓存介绍使用 Spring 2.5 注释驱动的 IoC 功能虚拟化 libvirt kvm 虚拟机上网 – Bridge桥接KVM详解&#xff0c;太详细太深入了&#xff0c;经典Tomcat Linux机器同时运行两个tomcat点评&#xff1a;主要是那张图片的配置 Nginx …

Flask爱家租房--celery(发送验证短信)

0.配置文件 # coding:utf-8BROKER_URL "redis://127.0.0.1:6379/1" CELERY_RESULT_BACKEND redis://127.0.0.1:6379/21.启动文件 # coding:utf-8from celery import Celery from ihome.tasks import config# 定义celery对象 celery_app Celery("ihome"…

理论与实践:不要过度思考

你每天都在仔细翻阅Hacker News&#xff0c;惊奇于那些经过整理的创业传奇、功效无比的最佳实践理论、天才的技术解决方案&#xff0c;以及各种链接指向的大量的一站式的&#xff0c;极简主义的&#xff0c;色彩柔和的网站。你参加过精益(Lean)创业研讨会&#xff0c;读过了《F…

linux我如何查看一个脚本的路径,linux获取shell脚本所在绝对路径操作介绍

脚本名&#xff1a;a.sh位置&#xff1a;/tmp/whuang/study/java脚本内容&#xff1a;复制代码代码如下:#!/bin/shthis_dirpwddirname $0|grep "^/" >/dev/nullif [ $? -eq 0 ];thenthis_dirdirname $0elsedirname $0|grep "^/." >/dev/nullretval$…

Go编程技巧--io.Reader/Writer

Go原生的pkg中有一些核心的interface&#xff0c;其中io.Reader/Writer是比较常用的接口。很多原生的结构都围绕这个系列的接口展开&#xff0c;在实际的开发过程中&#xff0c;你会发现通过这个接口可以在多种不同的io类型之间进行过渡和转化。本文结合实际场景来总结一番。 总…