MySQL索引面试题面经汇总

一、索引

1. MySQL如何实现的索引?

三种:

  1. B+树索引:主要,重点
  2. hash索引:配合b+树索引使用,没法手动创建
  3. 全文索引:对于整个数据做全文的摘要索引

2. innodb和Myisam索引的区别?

  • innodb索引本身就在数据中,也就是说数据文件和索引文件在同一个
  • innodb的辅助索引data域相应记录主键的值而不是地址

3. 一个表中如果没有创建索引,会有b+树吗

答:如果建表的时候指定了主键,则会有聚簇索引,如果表没有创建主键那么在表的内部也会有一个隐式的主键,这么做的目的是为了更好的帮你管理,所以也是有的

4. 说一下b+树索引的实现原理

在b+树中,每一个页作为一个节点,而页的存储大小是固定的,在innodb中,页的默认大小是16kb,而在b+树中,非叶子节点是不存储数据的,只存储键值(key),因为页的大小是固定的,如果不存储数据,就可以存储更多的key,那么树的阶就会变大,树就会变的矮而盘,树的深度就会变少,这样查询的时候对硬盘的io次数就会变少,查询效率也就会变快

5. 聚簇索引和非聚簇索引有什么区别

在存储原理上,两者都是用b+数实现的,不过非聚簇索引多了一个回表的操作,也就是在根节点存储的不是行数据,而是主键的值,等查询到主键的值还需要再对主键的b+数进行查找,才能最终返回数据。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当谈到MySQL索引面试题时,有几个常见的问题和概念,我会尽力回答。请记住,以下答案仅供参考。 1. 什么是索引索引是一种数据结构,用于提高数据库查询的速度。它可以让数据库系统更快地定位到所需数据,而不必扫描整个表。 2. MySQL中常见的索引类型有哪些? MySQL常见的索引类型包括主键索引(Primary Key Index)、唯一索引(Unique Index)、普通索引(Index)和全文索引(Full-Text Index)等。 3. 主键索引和唯一索引有何区别? 主键索引是用于唯一标识每一行数据的索引,它必须是唯一且非空的。而唯一索引允许数据列中的值有重复,但是索引列的值必须是唯一的。 4. 什么时候应该使用索引? 当查询的频率高、需要快速定位到特定数据行或避免全表扫描时,使用索引可以提高查询性能。然而,过多或不恰当的索引可能会降低性能。 5. 索引数据库性能的影响是什么? 索引可以快查询速度,但同时会导致插入、更新和删除操作变慢,因为每次修改数据时都需要更新索引。过多的索引也会占用磁盘空间。 6. 如何优化索引性能? 可以通过以下方式进行索引性能优化: - 选择合适的索引类型; - 选择适当的索引列; - 避免过多或重复的索引; - 使用覆盖索引减少IO操作; - 定期维护索引,删除不必要的索引。 这些只是一些常见的MySQL索引面试题,希望能对你有所帮助。如果你有其他问题,请随时提问!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值