mysql关于索引的面试题

preview
需积分: 0 0 下载量 93 浏览量 更新于2023-04-07 收藏 15KB DOCX 举报
MySQL中的索引是数据库性能优化的关键工具,它能显著提高数据检索的速度。下面将详细讨论索引的类型、存储方式以及可能导致索引失效的场景。 我们来看一下索引的类型: 1. **主键索引(Primary Key Index)**:这是最特殊的索引类型,用于唯一标识表中的每一行记录,且不允许有NULL值。主键可以是单个字段,也可以是多个字段的组合。 2. **唯一索引(Unique Index)**:与主键类似,保证索引中的每一项都是唯一的,但不强制成为主键。允许有NULL值。 3. **普通索引(Index)**:最基本的索引类型,允许重复的值和NULL值。 4. **空间索引(Spatial Index)**:用于处理地理空间数据,如点、线、多边形等。 5. **全文索引(Full-text Index)**:用于全文搜索,对文本进行分词并建立索引,便于高效地进行文本搜索。 接下来,我们讨论索引的存储方式: 1. **B-树索引(B-Tree Index)**:这是最常见的索引类型,适合有序的数据查询,如等值比较、范围查询等。B-树索引确保了索引和数据的排序,使得查找、插入和删除操作的时间复杂度为O(log n)。 2. **哈希索引(Hash Index)**:哈希索引主要基于哈希函数,通过哈希值快速定位数据,适合等值查询,但不支持范围查询。它的查找速度非常快,通常为O(1),但若哈希冲突,效率会下降。 现在,我们来分析索引可能失效的情况: 1. **计算、函数、类型转换**:当索引字段被用于计算或函数中,或者在比较时发生了隐式或显式的类型转换,数据库可能无法使用索引。 2. **联合索引**:如果在联合索引的条件中,只有部分列被用作等值查询,而后面的列被用作范围查询,那么从范围查询的列开始的索引将不会被使用。 3. **不等于操作(!= 或 <>)**:不等于操作通常不会利用到索引,除非该字段有索引且数据库可以使用其他策略来优化查询。 4. **IS NULL 和 IS NOT NULL**:对于IS NULL,索引可以被使用;但对于IS NOT NULL,大多数情况下索引无法发挥作用。 5. **LIKE操作符**:以通配符%开头的模式匹配会导致索引失效,因为这种查询是从中间或末尾开始的,无法利用B-树索引的有序性。 6. **OR操作符**:当OR前后包含非索引列时,即使其他列有索引,整个查询也可能无法使用索引。 提一下数据库和表的字符集选择。在MySQL中,推荐使用`utf8mb4`字符集,因为它支持更广泛的Unicode字符,包括表情符号,这对于全球化应用至关重要。 理解并熟练掌握这些索引知识,将有助于优化SQL查询,提升数据库的性能,对于求职面试和实际工作都十分有帮助。在设计数据库和编写SQL时,合理创建和使用索引,避免上述导致索引失效的场景,是每个数据库管理员和开发者的必备技能。