数据结构行编辑成簇 c语言,索引的数据结构及底层存储

索引是帮助数据库高效获取数据的数据结构

索引的数据结构

1.hash表

bVcLSS8

a.利用hash存储的话需要将所有的数据文件添加到内存,比较耗费内存空间

b.hash表存储的是无序数据,范围查找的时候需要挨个进行遍历,比较耗费时间。

2.二叉树

bVcLSVf

二叉树规定左子树必须小于根节点,右子树必须大于根节点,可能会导致右子树变成一条链表,对提升查询效率没有帮助。

3.平衡树(AVL树)

bVcLSWQ

AVL树是一颗严格意义上的平衡树,它要求最高子树和最低子树的高度之差不超过1,因此在进行元素插入的时候,会进行1到n次的旋转,严重影响插入的效率。

4.红黑树

bVcLSZy

红黑树是基于AVL树的一个升级,损失了部分查询的性能,来提升插入的性能,在红黑树中,最高子树不能超过最低子树的2倍,在插入的时候,不需要进行N多次的旋转操作,而且加入了变色的特性,来满足插入和查询性能的平衡。ps:二叉树及其变种的其他树都不能支撑索引的需求,原因是其插入数据的性能比较低,并且树的深度无法控制,都会因为树的深度过深而造成io的次数变多,影响读取数据的效率。

5.B-Tree

bVcLThR

B树的特点:

1.所有键值分布在整颗树上

2.搜索可能在非叶子节点上结束,在关键字全集内做一次查找,性能逼近二分查找

3.节点中的数据索引从左到右递增排列

缺点:每个节点同时包含了key和data,而每个页存储空间是有限的,

如果data比较大的话会导致每个节点存储的元素数量变小。

当存储量变大时,会导致深度变大,增大磁盘io次数,进而影响查询性能。

6.B+Tree

bVcLTEz

B+Tree是在B-Tree的基础之上做的一种优化:

1.B+Tree的非叶子节点只存储索引,不存储data,使非叶子节点可以包含更多的节点,这样有两个好处,一是大大降低了树的高度,二是将数据范围变成多个区间,增加了检索的效率。

2.叶子节点存储所有的索引和data,而且所有的叶子节点相互连接,形成了一种链式结构,范围查询性能更高。ps:索引的从磁盘到内存的load过程中会产生磁盘I/O消耗,相对于内存读取,I/O存取的消耗要高好几个数量级,所以评价一个数据结构作为索引的优劣最重要的指标就是在查找过程中磁盘I/O操作次数。换句话说,索引的结构组织要尽量减少查找过程中磁盘I/O的存取次数。B+Tree这种数据结构利用了磁盘预读原理,将每个节点的大小设为等于一个页,每个节点只需要一次I/O就可以载入,并且节点中的数据和索引从左到右递增排列,符合局部性原理,所以B+Tree拥有更好的性能。

InnoDB索引实现

聚簇索引

在InnoDB这种存储引擎下,数据和索引是放在一起的.frm存放的是表结构.ibd存放表数据和索引

ps:innoDB存储引擎默认情况下会把所有的数据文件放到表空间中,不会单独为每一张表保存一份数据文件,如果需要将每一张表单独使用文件保存,设置如下属性:set gobal innodb_file_per_table=on

InnoDB--B+Tree

bVcLTN4

1.叶子节点直接存放索引和数据

2.InnoDB中至少有一个聚簇索引,一般会通过B+Tree对主键创建索引,如果没有主键,会选择唯一键,如果没有唯一键,会自动生成一个6位rowid来作为主键

3.在非聚簇索引中,叶子节点上存储的是该行数据的主键,然后通过聚簇索引找到对应的数据,也就是要走两次B+Tree,叫做回表

MyISAM索引实现

非聚簇索引

在MyISAM这种存储引擎下,数据和索引文件是单独的文件.frm存放的是表结构.MYI存放索引.MYD存放表数据

MyISAM--B+Tree

bVcLTZt

1.叶子节点存放索引和对应数据的磁盘文件地址

2.MyISAM不存在回表的问题

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

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

相关文章

The C Programming Language--可变参数的函数

函数 printf的正确声明形式为:int printf(char *fmt, ...) void va_start (va list ap, last-required) type va_arg (va list ap, type) void va_end (va list ap) 其中,省略号表示参数表中参数的数量和类型是可变的。 va_list 类型用于声明一个变量&am…

cifar10 c语言,Python3读取深度学习CIFAR-10数据集出现的若干问题解决

今天在看网上的视频学习深度学习的时候,用到了CIFAR-10数据集。当我兴高采烈的运行代码时,却发现了一些错误:# -*- coding: utf-8 -*-import pickle as pimport numpy as np import os def load_CIFAR_batch(filename): """ 载…

各种排序算法总结

转载:http://blog.csdn.net/warringah1/article/details/8951220 明天就要去参加阿里巴巴的实习生笔试了,虽然没想着能进去,但是态度还是要端正的,也没什么可以准备的,复习复习排序吧。 1 插入排序 void InsertSort(in…

CentOS7 上安装 Zookeeper-3.4.9 服务

在 CentOS7 上安装 zookeeper-3.4.9 服务1、创建 /usr/local/services/zookeeper 文件夹: mkdir -p /usr/local/services/zookeeper 2、进入到 /usr/local/services/zookeeper 目录中: cd /usr/local/services/zookeeper 3、下载 zookeeper-3.4.9.…

HTTP响应报文与工作原理详解

HTTP 是一种请求/响应式的协议,即一个客户端与服务器建立连接后,向服务器发送一个请求;服务器接到请求后,给予相应的响应信息。 超文本传输协议(Hypertext Transfer Protocol,简称HTTP)是应用层协议。HTTP 是一种请求/响应式的协议…

android自定义画板,android 自定义控件 -- 画板

如图:package com.example.myview;import android.content.Context;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.graphics.Path;import android.graphics.Paint.Style;import android.util.Attrib…

postgreSQl pathman 用法语句总结

2019独角兽企业重金招聘Python工程师标准>>> --新建主表 create table part_test(id int, info text, crt_time timestamp not null); --插入测试数据 insert into part_test select id,md5(random()::text),clock_timestamp() (id|| hour)::interval from generat…

C#-面向对象的多态思想 ---ShinePans

总结: 多态是面向对象的核心.---------能够理解为一个方法,多种实现, 在这里能够用虚方法,抽象类,接口能够实现多态 1.首先利用接口来实现多态: 接口相当于"功能,"接口能够实现多继承,分为 显式实现接口和隐式实现接口 keyword为interface格式: interface 接口名 { …

android jar导出,Android项目导出jar包的小技巧

我们知道,可以通过如下设置将一个普通的Android工程转换成Android Library工程设置前后工程变化如下使用Ant编译时(通过android.bat update project 命令生成 build.xml),普通的Android工程会生成apk文件,而Android Library工程只生成jar文件…

(五十九)iOS网络基础之UIWebView简易浏览器实现

【UIWebView网络浏览器】 通过webView的loadRequest方法可以发送请求显示相应的网站,例如: NSURL *url [NSURL URLWithString:"http://m.baidu.com"];// 创建请求数据NSURLRequest *request [NSURLRequest requestWithURL:url];// 向服务器发…

无心插柳OR志在必得?阿里推“来往”的意图

近年来,阿里巴巴在外围的动作确实不少,投资新浪微博、投资陌陌,配合阿里自身的一些战略调整,让人觉得这家公司似乎正在经历一场前所未有的“蜕变”。其实这也不难理解,在BAT三国演义中,任何一方都不能对其他…

wampserver的mysql启动与环境变量设置

安装好wampserver以后,mysql服务默认已经启动了。但是直接在命令行里输入"mysql",系统会提示说 mysql 不是内部或外部命令,也不是可运行的程序或批处理文件。 这是因为没有增加“mysql”环境变量,请跳到第3步阅读。 如果之前已经安…

华为mate30怎么申请鸿蒙内测,华为新系统启动内测,mate30系列尝鲜,网友:羡慕...

原标题:华为新系统启动内测,mate30系列尝鲜,网友:羡慕一款手机是否好用,其实取决于两个方面,一个是硬件,另一个则是软件,大家在购机的时候往往最关注的就是硬件配置,因为…

VMware 11完全安装Mac OS X 10.10

----------------------------------------- 引用原文如下: VMware 11安装Mac OS X 10.10_百度经验 http://jingyan.baidu.com/article/ff411625b9011212e48237b4.html VM11安装Mac OS X 10.10 工具/原料 1.VMware Workstation 11 2.unlocker 203(for OS…

用C语言写解释器(一)——我们的目标

声明为提高教学质量,我所在的学院正在筹划编写C语言教材。《用C语言写解释器》系列文章经整理后将收入书中“综合实验”一章。因此该系列的文章主要阅读对象定为刚学完C语言的学生(不要求有数据结构等其它知识),所以行文比較罗嗦&…

1_MVC+EF+Autofac(dbfirst)轻型项目框架_core层(以登陆为例)

前言 在上一篇0_MVCEFAutofac(dbfirst)轻型项目框架_基本框架中,我已经介绍了这个轻型框架的层次结构,在下面的这篇文章中,我将以教师登陆功能为例,具体来扩充下我的core层的代码。 在这之前,我想先补充讨论下是否有必…

Python实现atm机的功能

主要还是参考网上内容,自己做了修改。虽然代码有小bug,但是不影响学习和测试。功能:1.额度:80002.可以提现,手续费5%3.每月最后一天出账单,写入文件4.记录每月日常消费流水5.提供还款接口1.atm的脚本[rootp…

使用Vitamio打造自己的Android万能播放器(7)——在线播放(下载视频)

前言 本章将实现非常实用的功能——下载在线视频。涉及到多线程、线程更新UI等技术,还需思考产品的设计,如何将新加的功能更好的融入到现有的产品中,并不是简单的加一个界面就行了,欢迎大家交流产品设计和技术细节实现&#xff01…

HTML声明文档类型后样式出错,doctype如何声明

如何doctype声明,新增的结构元素和功能元素HTML5已形成了最终的标准,概括来讲,它主要是关于图像,位置,存储,多任务等功能的增加。 新增的元素有绘画 canvas ,用于媒介回放的 video 和 audio 元素…

Error-Project facet Java version 1.8 is not supported

最近导入最新的Strtus2.5.10.1 Demo时出现了这个错误 解决方案如下: 选中工程——右键——Properties 然后依次展开找到如图所示内容,将1.8改成1.7即可。 原因:工程默认配置是1.8,而本地环境JDK版本为1.7,两则不匹配造…