登录
首页 >  数据库 >  MySQL

【MySQL】存储引擎概述

来源:SegmentFault

时间:2023-02-24 18:35:07 476浏览 收藏

小伙伴们对数据库编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《【MySQL】存储引擎概述》,就很适合你,本篇文章讲解的知识点主要包括MySQL、数据库。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!

MySQL 数据库区别于其他数据库的最重要的一个特别就是其插件式的表存储引擎。MySQL 存储引擎提供了一系列标准的管理和服务支持,每个存储引擎是底层物理结构的实现。

需要注意的是,存储引擎是基于表的,而不是数据库。

InnoDB

InnoDB 存储引擎支持事务,其特点是行锁设计、支持外键、并支持类似于 Oracle 的非锁定读,即默认读取操作不会产生锁。

从 MySQL 数据库 5.5.8 开始,InnoDB 存储引擎是默认的存储引擎。

InnoDB 通过使用多版本并发控制(MVCC)来获得高并发性,并且实现了 4 种隔离级别,默认是 REPEATABLE (可重复读)级别。同时,使用一种被称为 next-key-locking 的策略来避免幻读(phantom)现象的产生。除此之外,InnoDB 存储引擎还提供了插入缓存(insert buffer)、二次写(double write)、自适应哈希索引(adaptive hash index)、预读(read ahead)等高性能和高可用的功能。

对于表中数据的存储,InnoDB 存储引擎采用了聚集的方式,因此每张表的存储都是按主键的顺序进行存放。如果没有显式地在表定义时指定主键,InnoDB 存储引擎会为每一行生成一个 6 字节的 ROWID,并以为作为主键。

MyISAM

MyISAM 存储引擎不支持事务、表锁设计,支持全文索引。在 MySQL 5.5.8 版本之前,MyISAM 是默认的存储引擎。

此外,MyISAM 存储引擎的另一个与众不同的地方是它的缓冲池只缓存索引文件,而不缓冲数据文件,这点和大多数的数据库都非常不同。

MyISAM 存储引擎表由 MYD 和 MYI 组成,MYI 用来存放数据文件,MYI 用来存放索引文件。

好了,本文到此结束,带大家了解了《【MySQL】存储引擎概述》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>