数据结构行编辑成簇 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,一经查实,立即删除!

相关文章

卓同学的 Swift 面试题

我觉得应该掌握的知识点,没有实际意义。 class 和 struct 的区别不通过继承,代码复用(共享)的方式有哪些Set 独有的方法有哪些?实现一个 min 函数,返回两个元素较小的元素map、filter、reduce 的作用map 与…

使用CImage双缓冲

一普通显示:现在的VC显示图片非常方便,远不是VC6.0那个年代的技术可比,而且支持多种格式的如JPG,PNG。 CImage _img; 初始化: _img.Load(L"map.png"); 显示:OnPaint事件中 CRect rect; this…

汇编语言学习系列 for循环实现

假如汇编语言要实现如下C语言的功能&#xff0c;编译环境Ubuntu14.04&#xff08;32位&#xff09;。 #include<stdio.h> int fact_for(int n) {int i;int result 1;for(i 2; i < n; i)result * i;return result; }int main(){printf("%d\n", fact_for(3)…

川大锦城c语言期末考试答案,四川大学《计算机组成原理》2018期末考试B卷答案及评分标准.doc...

四川大学期末考试试题(闭卷)答案及评分标准(2017——2018学年第 2 学期) B卷课程号&#xff1a;304036030 课程名称&#xff1a;计算机组成原理填空题(本大题共15空&#xff0c;每空2分&#xff0c;共30分)在评价计算机性能时用 响应时间 表示计算机完成某任务所需时间;用 吞吐…

2014届华为校园招聘机试题2

第一题、输入一个正整数&#xff0c;并编码为字符串进行输出 描述: 1、输入一个正整数&#xff0c;并编码为字符串进行输出。 编码规则为&#xff1a;数字0-9分别编码为字符a-j 2、输入肯定是正整数&#xff0c;不用做错误较验 运行时间限制: 无限制 内存限制: 无限制 输…

图解phpstorm常用快捷键

查询快捷键 CTRLN 查找类 CTRLSHIFTN 全局搜索文件 ,优先文件名匹配的文件 CTRLSHIFTALTN 查找php类名/变量名 ,js方法名/变量名, css 选择器 CIRLB 找变量的来源&#xff0c;跳到变量申明处 (CTRL 鼠标单击 也可以) CTRLALTB 找到继承该接口或者父级 的所有子类, 统计所有子类…

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

函数 printf的正确声明形式为&#xff1a;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) 其中&#xff0c;省略号表示参数表中参数的数量和类型是可变的。 va_list 类型用于声明一个变量&am…

二分查找法的循环与递归实现及时间复杂度分析

转载&#xff1a;http://baike.baidu.com/link?url3aEK-qcVbYi6ioJOsf-dFmvFQ6WQgzTwnE9JkmlHBc88qk-D00SambfrSl3hVh_UyqyxF8QEUosfq20IQQW5z_ 和http://hi.baidu.com/networkor/item/80d817f8331d8e08a7298834 设数组为整数数组&#xff0c;从小到大排序。二分法强调一定是…

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

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

Java程序性能优化

一、避免在循环条件中使用复杂表达式 在不做编译优化的情况下&#xff0c;在循环中&#xff0c;循环条件会被反复计算&#xff0c;如果不使用复杂表达式&#xff0c;而使循环条件值不变的话&#xff0c;程序将会运行的更快。 例子&#xff1a; import java.util.vector; class …

asp.net表单提交方法:GET\POST介绍

表单form的提交有两种方式&#xff0c;一种是get的方法&#xff0c;一种是post 的方法&#xff0c;如果没有特殊指定&#xff0c;默认为post。看下面代码,理解ASP.NET Get和Post两种提交的区别: 1.< form id"form1" method"get" runat"server"…

各种排序算法总结

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

CentOS7 上安装 Zookeeper-3.4.9 服务

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

c语言在程序中显示现在星期几,C语言程序设计: 输入年月日 然后输出是星期几...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼#include main(){int year,month,day0,a,b,week,c,i,sum0,days,d;printf("please input year,month,days\n");scanf("%d,%d,%d",&year,&month,&days);for(i1;i{if (year%40){if(year%1000){if (ye…

static之用法

本文转载于http://www.cnblogs.com/stoneJin/archive/2011/09/21/2183313.html 在C语言中&#xff0c;static的字面意思很容易把我们导入歧途&#xff0c;其实它的作用有三条。 &#xff08;1&#xff09;先来介绍它的第一条也是最重要的一条&#xff1a;隐藏。 当我们同时编译…

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

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

优先队列priority_queue 用法详解

转载&#xff1a; 1.优先队列priority_queue 用法详解 2.STL系列之五 priority_queue 优先级队列 优先队列是队列的一种&#xff0c;不过它可以按照自定义的一种方式&#xff08;数据的优先级&#xff09;来对队列中的数据进行动态的排序 每次的push和pop操作&#xff0c;队…

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

如图&#xff1a;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…

Oracle查询笔记

-- tanslate(str,from_str,to_str) -- 将str中的from_str替换成to_str select translate(hello,e,o) t from dual;-- instr(str,des_str) -- 可以实现like功能 select instr(hello,g),instr(hello,h),instr(hello,l) from dual; -- decode(value,s1,r1,s2,r2,default) -- 类似于…