唯一索引和普通索引的区别,以及changeBuffer

一,changeBuffer起源

首先Innodb存储引擎,将数据库文件分为记录文件和索引文件,当数据增删改的时候,就需要需改数据文件(这个是必须的),还需要需改索引文件。
索引文件其实是次要的,因为频繁修改索引文件产生的大量随机IO就显得很没有必要。
changeBuffer应运而生。

二,changeBuffer作用

changeBuffer是Buffer Pool的一部分,用来对二级非唯一索引进行缓存。这样当操作命中缓存中的索引时,就可以将操作进行合并,在相对空闲时再进行写入磁盘操作,从而减少IO频率,提高性能。

三,唯一索引和普通索引的区别

那么就可以看出来了,普通的二级索引可以使用changeBuffer,而唯一索引不可以。所以理论上,普通索引的增删效率会比唯一索引高。

四,唯一索引为什么不可以使用changeBuffer?

changeBuffer的目的是减少查询索引表,而唯一索引的操作要校验索引字段的唯一性,无法避免查询索引表,故而不能使用changeBuffer.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值