数据库存储引擎

数据库存储引擎

今天面试被问到关于数据库索引的相关问题,没答出来,所以整理如下:

1.数据库的引擎

存储引擎:MySQL中的数据、索引以及其它对象是如何存储的,是一套文件系统的实现。

常用的存储引擎如下:

  • InnoDB :InnoDB引擎提供了对数据库ACID事物的支持。提供了行级锁和外键的约束。设计目标是处理大数据容量的数据库系统。
  • MyISAM引擎 :(原本是MySQL默认引擎)不提供事物的支持,也不提供行级锁和外键。
  • MEMORY引擎 :所有的数据都在内存中,数据的处理快,但是安全性不高。

2.MyISAM索引和InnoDB索引的区别

  • InnoDB索引是聚簇索引,MyISAM索引是非聚簇索引
  • InnoDB的主键索引的叶子结点存储着行数据,因此主键索引非常高效
  • MyISAM索引的叶子结点存储的是行数据地址,需要再进行一次寻址才能得到数据
  • InnoDB非主键索引的叶子结点存储的是主键和其它带索引的列数据,因此查询时做到覆盖索引会非常高效

3.InnoDB引擎的四大特性

  • 插入缓冲
  • 二次写
  • 自适应哈希索引
  • 预读

4.存储引擎选择

MyISAM :以读写插入为主的应用程序,比如博客系统,新闻门户网站

InnoDB : 更新删除操作频率较高,或者要保证数据的完整性,并发量高,支持事物和外键。比如OA自动化办公系统。没有特别的要求,默认使用InnoDB即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值