Mysql之存储引擎


(1)inndob存储引擎:inndob的数据存储在表空间中,将每个表的数据和索引存放在单独的文件中。其默认隔离级别是REPEATABLE READ(可重复读),并且通过间隙锁策略防止幻读的出现。间隙锁使得Innodb不仅仅锁定查询涉及的行,还会对索引的间隙进行锁定,防止幻影行的插入;innodb基于聚簇索引建立。innodb内部做了很多优化,包括从磁盘读取数据时采用的可预测性预读,能够自动在内存中创建hash索引以加速读操作的自适应性hash索引,以及能够加速插入缓冲区。

(2)MyISAM存储引擎:其提供了全文索引、压缩、空间函数等特性,但MyISAM不支持事务和行级索,崩溃后无法安全恢复。对于只读的数据,或者表比较小的数据,可进行修复。其将表存储在两个文件中:数据文件和索引文件,也支持静态或者动态行。对整张表加锁;即使是Blog或者Text等长字段,也可以基于其前500个字符创建索引。支持全文索引,也支持复杂索引;创建MyISAM表时,若指定了DELAY_KEY_WRITE选项,在每次修改执行完成后,不会立刻将修改的索引数据写入磁盘,而是会写到内存中的键缓冲区,只有在清理键缓冲区或者关闭表的时候才会将对应的索引块写入到磁盘;MYISAM的压缩表可以极大地减少磁盘空间占用,因此也可以减少磁盘I/O,提升查询性能。

 

聚簇索引:innodb的聚簇索引实际上是在同一个结构中保存了B-TREE索引和数据行。该索引中键值的逻辑顺序决定了表中相应行的物理顺序。

  聚集索引确定表中数据的物理顺序。聚集索引类似于电话簿,后者按姓氏排列数据。由于聚集索引规定数据在表中的物理存储顺序,因此一个表只能包含一个聚集索引。但该索引可以包含多个列(组合索引),就像电话簿按姓氏和名字进行组织一样。

聚集索引对于那些经常要搜索范围值的列特别有效。使用聚集索引找到包含第一个值的行后,便可以确保包含后续索引值的行在物理相邻。例如,如果应用程序执行的一个查询经常检索某一日期范围内的记录,则使用聚集索引可以迅速找到包含开始日期的行,然后检索表中所有相邻的行,直到到达结束日期。这样有助于提高此类查询的性能。同样,如果对从表中检索的数据进行排序时经常要用到某一列,则可以将该表在该列上聚集(物理排序),避免每次查询该列时都进行排序,从而节省成本。当索引值唯一时,使用聚集索引查找特定的行也很有效率。例如,使用唯一雇员 ID 列 emp_id 查找特定雇员的最快速的方法,是在 emp_id 列上创建聚集索引或 PRIMARY KEY 约束。

非聚集索引:该索引中索引的逻辑顺序与磁盘上行的物理存储顺序不同。

索引是通过二叉树的数据结构来描述的,我们可以这么理解聚簇索引:索引的叶节点就是数据节点。而非聚簇索引的叶节点仍然是索引节点,只不过有一个指针指向对应的数据块。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值