文章详情

短信预约信息系统项目管理师 报名、考试、查分时间动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MyISAM 和 InnoDB 索引结构及其实现原理

2016-02-15 00:08

关注

MyISAM 和 InnoDB 索引结构及其实现原理

  1. 数据库索引,是数据库管理系统中一个排序的数据结构,以协助快速查询、更新数据库表中数据。

  2. 索引的实现通常使用B_TREE。
    B_TREE索引加速了数据访问,因为存储引擎不会再去扫描整张表得到需要的数据;
    相反,它从根节点开始,根节点保存了子节点的指针,存储引擎会根据指针快速寻找数据。

  3. MyISAM引擎 使用B+Tree作为索引结构,叶节点的data域存放的是数据记录的地址.
    即:MyISAM索引文件和数据文件是分离的,MyISAM的索引文件仅仅保存数据记录的地址。
    MyISAM中索引检索的算法为首先按照B+Tree搜索算法搜索索引,
    如果指定的Key存在,则取出其data域的值,然后以data域的值为地址,读取相应数据记录。
    MyISAM的索引方式也叫做“非聚集”的。
    物理文件结构为:
    .frm文件:与表相关的元数据信息都存放在frm文件,包括表结构的定义信息等。
    .myd(mysql data)文件:myisam存储引擎专用,用于存储myisam表的数据
    .myi(mysql index)文件:myisam存储引擎专用,用于存储myisam表的索引相关信息

  4. InnoDB引擎 也使用B+Tree作为索引结构,但是InnoDB的数据文件本身就是索引文件,叶节点data域保存了完整的数据记录。
    这个索引的key是数据表的主键,因此InnoDB表数据文件本身就是主索引。这种索引叫做“聚焦索引”。
    InnoDB的辅助索引的data域存储相应记录主键的值而不是地址。
    换句话说,InnoDB的所有辅助索引都引用主键作为data域。
    聚集索引这种实现方式使得按主键的搜索十分高效,但是辅助索引搜索需要检索两遍索引:
    首先检索辅助索引获得主键,然后用主键到主索引中检索获得记录。
    InnoDB的索引实现后,不建议使用过长的字段作为主键,因为所有辅助索引都引用主索引,过长的主索引会令辅助索引变得过大。
    在InnoDB中也不建议使用非单调的字段作为主键,
    因为InnoDB数据文件本身是一颗B+Tree,非单调的主键会造成在插入新记录时数据文件为了维持B+Tree的特性而频繁的分裂调整,十分低效,建议使用自增字段作为主键。
    物理文件结构为:
    .frm与表相关的元数据信息都存放在frm文件,包括表结构的定义信息等。
    .ibd文件和.ibdata文件:
    这两种文件都是存放innodb数据的文件,之所以用两种文件来存放innodb的数据,是因为innodb的数据存储方式能够通过配置来决定是使用共享表空间存放存储数据,还是用独享表空间存放存储数据。
    独享表空间存储方式使用.ibd文件,并且每个表一个ibd文件;
    共享表空间存储方式使用.ibdata文件,所有表共同使用一个ibdata文件;
    觉得使用哪种方式的参数在mysql的配置文件中 innodb_file_per_table;

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯