热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

图形式理解myisam和innodb索引区别

mysql两大主要引擎为myisam和innodb,那这两个引擎有什么区别呢?我们先新建两个除了引擎不同其他完全相同的表。磁盘文件:

mysql两大主要引擎为myisam和innodb,那这两个引擎有什么区别呢?

我们先新建两个除了引擎不同其他完全相同的表。


磁盘文件:

MyIsam表的磁盘文件有三个,(以表名为 table_myisam 为例)


  1. table_myisam.frm      (保存表结构:  FoRM)
  2. table_myisam.MYI     (保存索引    MYisam Index)
  3. table_myisam.MYD      (保存数据   MYisam Data)

Innodb表的磁盘文件有三个,(以表名为 table_Innodb 为例)


  1. table_Innodb.frm      (保存表结构  FoRM)
  2. table_Innodb.ibd     (保存索引和数据   InoodB Data)

---------------------------------------------


数据存储

MyIsam:索引和数据是分离的,索引保存的是数据的物理地址(非聚簇索引),数据可以是离散的,如图:

(图片均来源网络)

Innodb:索引和数据是放在一块的,索引的叶子节点顺序保存了数据本身,而不是数据的物理地址(聚簇索引),如图:

 

---------------------------------------------


索引结构

当有多个索引时:

MyIsam:每个索引存储的都是数据的实际地址

 

优点:不管从什么索引搜索,都会直接定位到磁盘文件地址

缺点:当增删改数据时导致数据磁盘物理地址变更时,需要维护所有索引

Innodb:辅助索引上存储的是主键索引的值,也就是用非主键索引查找数据时,先通过辅助索引的值找到主键索引的值,再通过主键索引寻找数据,当无主键时,mysql自动创建一个隐藏的默认的6位整数作为主索引。

优点:当增删改数据时导致数据磁盘物理地址变更时不需要维护所有索引,大大减少了维护索引所花的时间

缺点:所有索引找到的是对应的主键值,需要再根据主键找实际数据。

点击这里查看博主其他博客


推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 三星W799在2011年的表现堪称经典,以其独特的双屏设计和强大的功能引领了双模手机的潮流。本文详细介绍其配置、功能及锁屏设置。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 本文介绍如何通过注册表编辑器自定义和优化Windows文件右键菜单,包括删除不需要的菜单项、添加绿色版或非安装版软件以及将特定应用程序(如Sublime Text)添加到右键菜单中。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
author-avatar
火鸟大叔
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有