索引的面试题

** 1 的MySQL的索引有哪些类型? **

MySQL目前主要有以下几种索引类型:

  1. 普通索引
    是最基本的索引,它没有任何限制.

  2. 唯一索引
    与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一.

  3. 主键索引
    是一种特殊的唯一索引,一个表只能有一个主键,不允许有空值。

  4. 组合索引
    指多个字段上创建的索引,只有在查询条件中使用了创建一个字段,索引才会被使用。使用组合索引时遵循最左前缀。

  5. 全文索引
    主要用来查找文本中的关键字,而不是直接与索引中的值相比较.fulltext索引跟其它索引大不相同,它更像是一个搜索引擎,而不是简单的,其中语句的参数匹配.fulltext索引配合匹配操作使用,而不是一般的where语句加像。它可以在create table,alter table,create index使用,不过目前只有char,varchar,text列上可以创建全文索引。值得一提的是,在数据量较大时候,现将数据放入一个没有全局索引的表中,然后再用CREATE index创建全文索引,要比先为一张表建立全文然后再将数据写入的速度快很多。

2.索引是不是越多越好

答案:是并不是越多越好,原因如下:
1。虽然索引大大提高了查询速度,同时却会降低更新表的速度,如对表进行插入,更新和删除。因为更新表时,不仅要保存数据,还要保存一下索引文件.
2。建立索引会占用磁盘空间的索引文件。一般情况这个问题不太严重,但如果你在一个大表上创建了多种组合索引,索引文件的会增长很快。索引只是提高效率的一个因素,如果有大数据量的表,就需要花时间研究建立最优秀的索引,或优化查询语句。

3.索引的数据结构是什么?
答案:索引的数据结构是B-Tree和B + Tree

mongdb的索引数据结构是B-Tree(B树)
mysql的索引数据结构是B + Tree(B+树)

B+树跟B树的优势:

1.单一节点存储更多的元素,使得查询的IO次数更少。

2.所有查询都要查找到叶子节点,查询性能稳定。

3.所有叶子节点形成有序链表,便于范围查询。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值