数据库存储引擎
今天面试被问到关于数据库索引的相关问题,没答出来,所以整理如下:
1.数据库的引擎
存储引擎:MySQL中的数据、索引以及其它对象是如何存储的,是一套文件系统的实现。
常用的存储引擎如下:
- InnoDB :InnoDB引擎提供了对数据库ACID事物的支持。提供了行级锁和外键的约束。设计目标是处理大数据容量的数据库系统。
- MyISAM引擎 :(原本是MySQL默认引擎)不提供事物的支持,也不提供行级锁和外键。
- MEMORY引擎 :所有的数据都在内存中,数据的处理快,但是安全性不高。
2.MyISAM索引和InnoDB索引的区别
- InnoDB索引是聚簇索引,MyISAM索引是非聚簇索引
- InnoDB的主键索引的叶子结点存储着行数据,因此主键索引非常高效
- MyISAM索引的叶子结点存储的是行数据地址,需要再进行一次寻址才能得到数据
- InnoDB非主键索引的叶子结点存储的是主键和其它带索引的列数据,因此查询时做到覆盖索引会非常高效
3.InnoDB引擎的四大特性
- 插入缓冲
- 二次写
- 自适应哈希索引
- 预读
4.存储引擎选择
MyISAM :以读写插入为主的应用程序,比如博客系统,新闻门户网站
InnoDB : 更新删除操作频率较高,或者要保证数据的完整性,并发量高,支持事物和外键。比如OA自动化办公系统。没有特别的要求,默认使用InnoDB即可。