我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQ中索引的实现方式

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQ中索引的实现方式

这篇文章主要介绍“MySQ中索引的实现方式”,在日常操作中,相信很多人在MySQ中索引的实现方式问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQ中索引的实现方式”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

首先,需要对相关背景知识进行了解:B-Tree & B+Tree、折半查找(Binary Search)、 数据库的性能问题和数据的基本存储结构。下面做简要分析:
  1.B-Tree & B+Tree
  http://en.wikipedia.org/wiki/B%2B_tree
  http://en.wikipedia.org/wiki/B-tree
  2.半查找(Binary Search)
  http://en.wikipedia.org/wiki/Binary_search_algorithm
  3.数据库的性能问题
  ① 磁盘IO性能非常低,严重的影响数据库系统的性能。
  ② 磁盘顺序读写比随机读写的性能高很多。
  4.数据的基本存储结构
  ①磁盘空间被划分为许多大小相同的块(Block)或者页(Page).
  ② 一个表的这些数据块以链表的方式串联在一起。
  ③ 数据是以行(Row)为单位一行一行的存放在磁盘上的块中,如图所示.
  ④ 在访问数据时,一次从磁盘中读出或者写入至少一个完整的Block。
  
  数据基本操作的实现
  基本操作包括:INSERT、UPDATE、DELETE、SELECT。
  1.SELECT
  ①定位数据
  ② 读出数据所在的块,对数据加工
  ③ 返回数据给用户
  2.UPDATE、DELETE
  ①定位数据
  ②读出数据所在的块,修改数据
  ③写回磁盘
  3.INSERT
  ①定位数据要插入的页(如果数据需要排序)
  ②读出要插入的数据页,插入数据.
  ③ 写回磁盘
  如何定位数据?
  4.表扫描(Table Scan)
  从磁盘中依次读出所有的数据块,一行一行的进行数据匹配。
  时间复杂度 是O(n), 如果所有的数据占用了100个块。尽管只查询一行数据,也需要读出所有100个块的数据。
   需要大量的磁盘IO操作,极大的影响了数据定位的性能。
  因为数据定位操作是所有数据操作必须的操作,数据定位操作的效率会直接影响所有的数据操作的效率。
  因此我们开始思考,如何来减少磁盘的IO?
  5.减少磁盘IO
  减少数据占用的磁盘空间:压缩算法、优化数据存储结构
  减少访问数据的总量:读出或写入的数据中,有一部分是数据操作所必须的,这部分称作有效数据。剩余的部分则不是数据操作必须的数据,称为无效数据。例如,查询姓名是‘张三’的记录。那么这条记录是有效记录,其他记录则是无效记录。我们要努力减少无效数据的访问。

到此,关于“MySQ中索引的实现方式”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQ中索引的实现方式

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql索引的实现方式

mysql 索引通过 b+ 树(平衡的多路搜索树)、哈希表(基于键值对的快速查找)和哈希索引变体(前缀哈希)实现,用于支持主键、唯一索引、普通索引、等值查询、范围查询、模糊搜索、全文搜索和空间数据搜索。选择合适的索引类型取决于数据的性质和查
mysql索引的实现方式
2024-08-01

数据库中索引的实现原理:B-tree索引

数据库会使用一些方式来存储、读取和修改数据,在实际的数据库管理中,数据库会同时使用B-tree和B+tree来存储数据。其中B-tree用于索引,B+tree用于存储实际记录。本文带来B-tree在数据库中的索引机制。B-tree即B树,它
数据库中索引的实现原理:B-tree索引
2024-01-22

MySQL中聚簇索引与非聚簇索引的实现

目录基本概念和作用说明聚簇索引非聚簇索引示例一:创建索引示例二:索引的选择示例三:索引的维护示例四:索引与性能http://www.lsjlt.com优化示例五:索引的限制结论与讨论引发点在mysql数据库中,索引是提高查询性能的关键工具。
MySQL中聚簇索引与非聚簇索引的实现
2024-09-18

MySQL8 全文索引的实现方法

目录创建索引使用索引总结创建索引之前未尝试过使用mysql8的全文索引,今天试一试看看什么效果,否则跟不上时代了都。创建索引非常简单,写句SQL就行。create table goods(id integer primary key
MySQL8 全文索引的实现方法
2024-08-19

mysql的联合索引(复合索引)的实现

联合索引 本文中联合索引的定义为(MySQL):ALTER TABLE `table_name` ADD INDEX (`col1`,`col2`,`col3`);联合索引的优点 若多个一条SQL,需要多个用到两个条件SELECT * FR
2022-05-29

PHP 中使用 Elasticsearch 实现分布式搜索引擎

简介:分布式搜索引擎是现代互联网应用中非常重要的一环,它能够实现快速的全文检索、高效的数据搜索和排序。Elasticsearch是一个基于Lucene的开源分布式搜索引擎,提供了强大的搜索和分析功能。本文将介绍如何在PHP中使用Elasti
2023-10-21

编程热搜

目录