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

电话销售做网站连云港seo优化公司

电话销售做网站,连云港seo优化公司,河南做个人网站,怎么建设一个属于自己的网站索引实现原理 索引:排好序的数据结构 优点:降低I/O成本,CPU的资源消耗(数据持久化在磁盘中,每次查询都得与磁盘交互) 缺点:更新表效率变慢,(更新表数据,还要…

索引实现原理

索引:排好序数据结构
优点:降低I/O成本,CPU的资源消耗(数据持久化在磁盘中,每次查询都得与磁盘交互)
缺点:更新表效率变慢,(更新表数据,还要更新索引),占用空间
分类:主键索引,唯一索引,单值索引,组合索引

索引的数据结构

Hash表(舍弃:不适合范围查找和排序)

hash 是一维数组 + 二维链表:取模后进行存储

对于hash算法的CRUD来讲,时间复杂度为O(1)
但对于范围查询和排序来讲,时间复杂度又从最好变为O(n)

在这里插入图片描述

二叉树(舍弃:自增序列无效)

理想情况
在这里插入图片描述

mysql不使用的原因:对于自增数据,树左倾或右倾形成链表,时间复杂度变回了O(n)
在这里插入图片描述

红黑树(舍弃:树会很高)

本质就是二叉树,相比较于二叉树,他有平衡功能(当一边高时,会自动更新根节点),又称为二叉平衡树
在这里插入图片描述

mysql 不使用原因:数据量大的时候,树会更高,查找到叶子节点效率也会慢,每层就是一次IO

B Tree(舍弃:每个节点存放数据,可以优化)

特点:在每个节点,放多个索引
优点:树就不会高,但每个节点都会存data数据,会占据很大的磁盘空间
在这里插入图片描述

B+ Tree(mysql默认)

优点:
1.非叶子节点不储data,只存储索引,可以放更多的索引
2.叶子节点包含所有索引+data字段,由双向链表排成一行(更好的实现范围查找和排序)
3.叶子节点用指针连接,提高区间访问的性能

mysql 默认每个节点为16KB,
例如:若使用bigInt的主键,每个节点大概可放1170 个索引,若树高3层,则为1170*1170 *16 约为2000多万索引

在这里插入图片描述

总结:(数据存叶子节点,双向链表)

BTree 和B+Tree都是多路搜索树,区别在于叶子节点和非叶子节点的处理。
1.BTree 每个节点都储存索引+数据,B+Tree 的非叶子节点只存储索引+指向叶子节点的指针,数据存到叶子节点,这样B+Tree 的非叶子节点就可以放更多的索引,树的层级也就降低了,这样查找更快,减少了磁盘IO
2.B+Tree 的叶子节点都有指针相连接,形成双向链接表,这样在范围和排序时更快,而BTree 的叶子节点没有相连接,范围查找时还得向父节点查找。所以B+Tree 的范围查找和排序更好

数据结构训练网址

https://www.cs.usfca.edu/~galles/visualization/Algorithms.html

http://www.yidumall.com/news/11118.html

相关文章:

  • 长沙seo排名公司济南seo整站优化招商电话
  • 做网站需要的技术 规范创建软件平台该怎么做
  • wordpress 用户介绍英文谷歌seo
  • 为什么要建设应急管理网站app推广地推接单网
  • 网上购物网站模板网络推广公司经营范围
  • 申请网站备案要多久陕西网站建设网络公司
  • 机械设计网站有哪些百度导航下载安装手机导航
  • 天津做网站的公司有哪些网络营销的市场背景
  • 活动策划公司网站上海网站seo公司
  • 网络推广运营是什么杭州seo网站建设靠谱
  • dw中网站建设的基本流程关键词名词解释
  • 浙江工业设计公司北京网站优化哪家好
  • 大数据比赛网站建设网页关键词排名优化
  • 手机触屏网站开发百度app免费下载安装
  • 做网站常用的背景图像如何创建自己的个人网站
  • 一个高端网站设计微指数查询
  • 网站源码路径济南做seo排名
  • 淄川政府网站建设托管如何进行市场推广
  • 云南做网站多少钱如何做品牌推广方案
  • 学做分类网站seo云优化
  • 江阳建设集团网站营销策划公司简介
  • 网站常用字体新站网站推广公司
  • 卖芒果的网络营销策划seo现在还有前景吗
  • 微信商城网站如何做济南网络营销外包
  • 网站备案信息真实核验单关键词热度分析
  • 安徽做网站公司竞价托管信息
  • p2p的网站建设在线外链推广
  • 网站建设方案书个人数字营销
  • 门户网站建设合同网络营销的优势和劣势
  • 专业论坛网站有哪些网站seo优化软件