面试:数据库索引常见问法

2024-01-19 10:52

本文主要是介绍面试:数据库索引常见问法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 索引有哪些类型


        普通索引:最基本的索引,没有任何约束限制。
        唯一索引:和普通索引类似,但是具有唯一性约束,可以有 null
        主键索引:特殊的唯一索引,不允许有 null,一张表最多一个主键索引
        组合索引:多列值组成一个索引,用于组合搜索,效率大于索引合并
        全文索引:对文本的内容进行分词、搜索
        覆盖索引:查询列要被所建的索引覆盖,不必读取数据行

  • 为什么要使用索引?它们对数据库性能有何影响?


  1. 加快数据检索速度:通过创建适当的索引,数据库可以更快地定位和访问所需的数据行,减少了全表扫描或索引范围扫描的需求,从而加快了数据检索速度。

  2. 减少磁盘IO操作:索引可以帮助数据库系统减少磁盘IO操作的次数。相比于全表扫描,使用索引可以只检索和加载部分数据页到内存中,减少了磁盘IO的开销。

  3. 优化查询性能:索引可以使查询语句更快速地执行,减少了查询的响应时间。通过使用索引,数据库可以快速定位到满足查询条件的数据行,避免了进行全表扫描的开销。

  4. 改善排序和聚合操作:索引可以显著提升排序和聚合操作的性能。例如,在执行ORDER BY子句时,如果有合适的索引可用,数据库可以直接利用索引中的排序顺序,而无需额外的排序操作。

  5. 对多表连接操作的优化:在涉及多个表的连接操作中,使用索引可以加速连接过程,减少连接的时间复杂度。

  • 创建索引有哪些注意点


  1. 索引应该建在查询应用频繁的字段,比如where 判断、 order 排序和 join 的(on)字段上创建索引。
  2. 索引的个数应该适量,索引需要占用空间,更新时候也需要维护。
  3. 区分度低的字段,例如性别,不要建索引。
  4. 频繁更新的值,不要作为索引,维护索引文件需要成本;还会导致页分裂,IO次数增多。
  5. 联合索引把散列性高(区分度高)的值放在前面为了更好的满足最左前缀匹配原则。
  6. 尽可能用联合索引代替多个单列索引(对于单列索引,MySQL基本只能使用一个索引,所以经常使用多个条件查询时更适合使用联合索引)。
  7. 过长的字段,使用前缀索引。当字段值比较长的时候,建立索引会消耗很多的空间,搜索起来也会很慢。我们可以通过截取字段的前面一部分内容建立索引,这个就叫前缀索引。
  8. 不建议用无序的值(例如身份证、UUID )作为索引,在插入时会造成叶子节点频繁分裂,出现磁盘存储的碎片化。
  • 如何选择合适的列来创建索引?


  1. 查询频率:选择经常被查询的列作为索引列。针对经常出现在WHERE子句或JOIN操作中的列进行索引可以显著提高查询性能。

  2. 列的选择性:选择具有高选择性的列作为索引列。选择性是指索引列中不同值的唯一性程度。如果列具有高选择性,即不同值较多,那么使用索引将更加有效。例如,一个性别列只有两个可能的值(男、女),则对该列创建索引的效果会比较有限。

  3. 列的大小和类型:通常情况下,较小的列更适合创建索引,因为它们占用较少的存储空间,并且在内存中加载更快。而过大的文本类型或二进制类型的列则不太适合创建索引。

  4. 数据的更新频率:如果某个列的数据频繁更新,那么对该列创建索引可能会导致索引维护的开销增加。因此,在选择索引列时,需要权衡查询性能的提升与更新开销之间的平衡。

  • 索引哪些情况下会失效呢


        1.查询条件包含or,可能导致索引失效

        2.如果字段类型是字符串,where时一定用引号括起来,否则会因为隐式类型转换,索引失效

        3.like通配符可能导致索引失效。

        4.联合索引,查询时的条件列不是联合索引中的第一个列,索引失效。

        5.在索引列上使用mysql的内置函数,索引失效。

        6.对索引列运算(如,+、-、*、/),索引失效。

        7.索引字段上使用(!= 或者 < >,not in)时,可能会导致索引失效。

        8.索引字段上使用is null, is not null,可能导致索引失效。

        9.左连接查询或者右连接查询查询关联的字段编码格式不一样,可能导致索引失效。

        10.MySQL优化器估计使用全表扫描要比使用索引快,则不使用索引。

这篇关于面试:数据库索引常见问法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/622195

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

一文详解MySQL索引(六张图彻底搞懂)

《一文详解MySQL索引(六张图彻底搞懂)》MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度,:本文主要介绍MySQL索引的相关资料,文中通过代码介绍的... 目录一、什么是索引?为什么需要索引?二、索引该用哪种数据结构?1. 哈希表2. 跳表3. 二叉排序树4.

Oracle数据库在windows系统上重启步骤

《Oracle数据库在windows系统上重启步骤》有时候在服务中重启了oracle之后,数据库并不能正常访问,下面:本文主要介绍Oracle数据库在windows系统上重启的相关资料,文中通过代... oracle数据库在Windows上重启的方法我这里是使用oracle自带的sqlplus工具实现的方

MySQL批量替换数据库字符集的实用方法(附详细代码)

《MySQL批量替换数据库字符集的实用方法(附详细代码)》当需要修改数据库编码和字符集时,通常需要对其下属的所有表及表中所有字段进行修改,下面:本文主要介绍MySQL批量替换数据库字符集的实用方法... 目录前言为什么要批量修改字符集?整体脚本脚本逻辑解析1. 设置目标参数2. 生成修改表默认字符集的语句3

Redis高性能Key-Value存储与缓存利器常见解决方案

《Redis高性能Key-Value存储与缓存利器常见解决方案》Redis是高性能内存Key-Value存储系统,支持丰富数据类型与持久化方案(RDB/AOF),本文给大家介绍Redis高性能Key-... 目录Redis:高性能Key-Value存储与缓存利器什么是Redis?为什么选择Redis?Red

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v