innodb和myisam的区别及索引实现原理

innodb和myisam是Mysql中常用的两种引擎,以下是两者的比较:
innodb myisam
对事务的支持 支持四种事务的隔离级别 不支持
支持的锁种类 行锁、页锁、表锁 表锁
是否支持全文索引 不支持 支持
索引 聚集索引 非聚集索引
并发 根据事务隔离级别 读写互相阻塞
储存 基于磁盘的资源是InnoDB表空间数据文件和它的日志文件 在磁盘中储存成三个文件,分别是:索引文件、数据文件、表定义
使用场景 事务要求高,对数据大量的修改操作… 事务要求不高,查询操作多、并发低…

下面看一下两者的索引实现的原理:

myisam:非聚集索引

采用B+树的数据索引结构
索引作为单独的文件储存起来,记录了数据的存放地址

在这里插入图片描述
上图以表的Col1字段作为主键,可以看出索引文件里储存的是数据主键的地址

innodb:聚集索引
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值