当前位置: 首页 > news >正文

网站开发标准合同网站怎么提高收录

网站开发标准合同,网站怎么提高收录,一建二建报考条件及专业要求,手表网站海马300米潜水表1 概述 MySQL的索引是在存储引擎层实现的,不同的存储引擎有不同的索引结构,主要包含以下几种: 索引结构描述BTree索最常见的索引类型,大部分引擎都支持 B 树索引 Hash索引 底层数据结构是用哈希表实现的, 只有精确匹配索引列的…

1 概述

MySQL的索引是在存储引擎层实现的,不同的存储引擎有不同的索引结构,主要包含以下几种:

索引结构描述
B+Tree索最常见的索引类型,大部分引擎都支持 B+ 树索引

Hash索引

底层数据结构是用哈希表实现的, 只有精确匹配索引列的查询才有效, 不支持范围查询

R-tree(空间索引)

空间索引是MyISAM引擎的一个特殊索引类型,主要用于地理空间数据类

型,通常使用较少

Full-text(全文索引)

是一种通过建立倒排索引,快速匹配文档的方式。类似于Lucene,Solr,ES

上述是MySQL中所支持的所有的索引结构,接下来,我们再来看看不同的存储引擎对于索引结构的支持情况。

索引InnoDBMyISAMMemory
B+tree索引支持支持支持
Hash 索引不支持不支持支持
R-tree 索引不支持支持不支持
Full-text 5.6版本之后支持支持不支持

注意:

我们平常所说的索引,如果没有特别指明,都是指B+树结构组织的索引。

2 二叉树

假如说MySQL的索引结构采用二叉树的数据结构,比较理想的结构如下:

如果主键是顺序插入的,则会形成一个单向链表,结构如下: 

所以,如果选择二叉树作为索引结构,会存在以下缺点:

  • 顺序插入时,会形成一个链表,查询性能大大降低。
  • 大数据量情况下,层级较深,检索速度慢。

 

此时大家可能会想到,我们可以选择红黑树,红黑树是一颗自平衡二叉树,那这样即使是顺序插入数据,最终形成的数据结构也是一颗平衡的二叉树,结构如下:

 

但是,即使如此,由于红黑树也是一颗二叉树,所以也会存在一个缺点:

  • 大数据量情况下,层级较深,检索速度慢。

所以,在MySQL的索引结构中,并没有选择二叉树或者红黑树,而选择的是B+Tree,那么什么是B+Tree呢?在详解B+Tree之前,先来介绍一个B-Tree。

3 B-Tree

B-Tree,B树是一种多叉路衡查找树,相对于二叉树,B树每个节点可以有多个分支,即多叉。

以一颗最大度数(max-degree)为5(5阶)的b-tree为例,那这个B树每个节点最多存储4个key,5个指针:

 

我们可以通过一个数据结构可视化的网站来简单演示一下。 https://www.cs.usfca.edu/~galles/visualization/BTree.html

 

插入一组数据: 100 65 169 368 900 556 780 35 215 1200 234 888 158 90 1000 88 120 268 250 。然后观察一些数据插入过程中,节点的变化情况。

 

特点:

  • 5阶的B树,每一个节点最多存储4个key,对应5个指针。
  • 一旦节点存储的key数量到达5,就会裂变,中间元素向上分裂。
  • 在B树中,非叶子节点和叶子节点都会存放数据。

4 B+Tree

B+Tree是B-Tree的变种,我们以一颗最大度数(max-degree)为4(4阶)的b+tree为例,来看一下其结构示意图:

 

我们可以看到,两部分:

  • 绿色框框起来的部分,是索引部分,仅仅起到索引数据的作用,不存储数据。
  • 红色框框起来的部分,是数据存储部分,在其叶子节点中要存储具体的数据。

我们可以通过一个数据结构可视化的网站来简单演示一下。 https://www.cs.usfca.edu/~galles/visualization/BPlusTree.html

插入一组数据: 100 65 169 368 900 556 780 35 215 1200 234 888 158 90 1000 88 120 268 250 。然后观察一些数据插入过程中,节点的变化情况。 

最终我们看到,B+Tree 与 B-Tree相比,主要有以下三点区别:

  • 所有的数据都会出现在叶子节点。
  • 叶子节点形成一个单向链表。
  • 非叶子节点仅仅起到索引数据作用,具体的数据都是在叶子节点存放的。

上述我们所看到的结构是标准的B+Tree的数据结构,接下来,我们再来看看MySQL中优化之后的B+Tree。

MySQL索引数据结构对经典的B+Tree进行了优化。在原B+Tree的基础上,增加一个指向相邻叶子节点的链表指针,就形成了带有顺序指针的B+Tree,提高区间访问的性能,利于排序。

 

5 Hash

MySQL中除了支持B+Tree索引,还支持一种索引类型---Hash索引。

(1)结构

哈希索引就是采用一定的hash算法,将键值换算成新的hash值,映射到对应的槽位上,然后存储在hash表中。

 

 

如果两个(或多个)键值,映射到一个相同的槽位上,他们就产生了hash冲突(也称为hash碰撞),可以通过链表来解决。

(2)特点

  • Hash索引只能用于对等比较(=,in),不支持范围查询(between,>,< ,...)
  • 无法利用索引完成排序操作
  • 查询效率高,通常(不存在hash冲突的情况)只需要一次检索就可以了,效率通常要高于B+tree索引

 

(3)存储引擎支持

在MySQL中,支持hash索引的是Memory存储引擎。 而InnoDB中具有自适应hash功能,hash索引是InnoDB存储引擎根据B+Tree索引在指定条件下自动构建的。

注意:

为什么InnoDB存储引擎选择使用B+tree索引结构?

  • 相对于二叉树,层级更少,搜索效率高;
  • 对于B-tree,无论是叶子节点还是非叶子节点,都会保存数据,这样导致一页中存储的键值减少,指针跟着减少,要同样保存大量数据,只能增加树的高度,导致性能降低;
  • 相对Hash索引,B+tree支持范围匹配及排序操作;

http://www.yayakq.cn/news/996390/

相关文章:

  • 404网站怎么打开seo虚拟外链
  • 开封网站建设培训班福田公司官网
  • 企业网站备案所需材料 amp长沙网站制作服务
  • php做企业网站管理系统网站建设哪家好 万维科技
  • 怎样选择网站建设公司安徽省建设厅网站职称
  • 赣州那里有做网站的公司最近国内重大新闻事件
  • 小米wifi设置网址入口网站高级ui设计是什么
  • 如何做网站同步别人的商城广州网站建设说说外链的建设
  • 怎么用虚拟主机做网站步骤学校网站开发与设计
  • WordPress建站评价免费做试卷的网站
  • 国外虚拟物品交易网站杰迅山西网站建设
  • 免费制作自己的微网站吗厦门住房建设局网站首页
  • 长沙 做营销型网站的公司广州大型网站建设
  • 新沂做网站商业招商网站
  • ps做 网站标准尺寸是多少合适做网站图结构
  • 为什么要建设旅游网站怎么建立一个网站里面可以查询资料
  • 简单的asp网站做网站专题页的字大小是多少
  • 建立网站需要投入的成本vs2008 新建网站
  • 建设局合同备案是哪个网站河南省城市建设网站
  • 网站免费制作教程百度知道一下首页
  • 网站建设什么原因最主要wordpress企业末班
  • 怎么建立网站数据库网站建设行业地位
  • 网站面包屑如何做cpanel安装wordpress中文教程
  • 北京门户网站网址如何在网站页面添加代码
  • 2016年做网站好不好90平方简装图3一4万
  • 湘潭网站推广爱企查企业信息查询
  • 凤阳县城乡建设局网站建设网站的相关技术指标
  • 南充网站设计电商平台网站开发
  • python 网站开发实战工业软件的前十名龙头
  • 网站建设公司排行榜智慧团建学生登录入口