高级java每日一道面试题-2024年9月29日-数据库篇-索引怎么定义,分哪几种?

devtools/2024/10/4 5:19:47/

如果有遗漏,评论区告诉我进行补充

面试官: 索引怎么定义,分哪几种?

我回答:

在Java高级面试中,尤其是涉及数据库数据结构的部分,索引(Index)是一个核心概念。索引的目的是提高数据库表中数据的检索速度,从而加快数据库查询、更新等操作的执行效率,特别是在处理大量数据时。不过,需要明确的是,索引通常是在数据库层面定义的,而不是直接在Java代码中定义(Java代码主要通过SQL语句来操作数据库,包括创建和管理索引)。但理解索引的原理和类型对于任何使用数据库的Java开发者都是非常重要的。

索引的定义

索引是一种数据结构,在数据库中用于帮助快速找到表中某一行的辅助数据结构索引可以建立在数据库表的一列或多列上,它是数据库管理系统自动创建的表之外的隐藏对象。使用索引后,数据库系统不必扫描整个表,就能迅速定位到某条记录的位置。

索引分类

索引可以根据不同的标准进行分类,主要包括以下几种:

按基本功能分类
  • 单列索引:只包含表中一个字段的索引
  • 复合索引(或多列索引):包含表中两个或两个以上字段的索引。创建复合索引时,会考虑索引中列的顺序。
  • 唯一索引:保证索引列的值唯一的索引。在唯一索引中,表中任意两行在索引列上的值都不能相同。
  • 主键索引:是表中的一列或多列的组合,其值能唯一地标识表中的每一行。实际上,主键索引就是一种特殊的唯一索引,且不允许有NULL值。
按字段数量分类
按唯一性分类
按物理存储方式分类
  • B-Tree索引:最常用的索引类型之一,适用于范围查询和排序。
  • Hash索引:基于哈希函数的索引,适用于等值查询。
  • Bitmap索引:使用位图表示数据的存在性,适用于低基数列(即列中唯一值较少的情况)。
  • R-Tree索引:适用于多维空间数据,如地理信息系统(GIS)。
  • 全文索引:主要用于搜索文本中的关键字,而不是直接比较索引中的值。
按逻辑角度分类
  • 聚集索引(Clustered Index):在关系型数据库中,聚集索引决定了数据行的物理存储顺序。每个表只能有一个聚集索引
  • 非聚集索引(Non-Clustered Index):不改变数据行的物理存储顺序,而是创建一个单独的数据结构来加速查询。每个表可以有多个非聚集索引
按存储方式分类
  • 内存索引索引数据完全存储在内存中,适用于高速读取。
  • 磁盘索引索引数据存储在磁盘上,适用于大规模数据集。

详解

B-Tree索引
  • 特点
    • 平衡树结构,所有叶子节点在同一层。
    • 支持范围查询和排序。
    • 插入、删除和查找操作的时间复杂度为O(log n)。
  • 适用场景
    • 范围查询(如 WHERE column BETWEEN ... AND ...)。
    • 排序查询(如 ORDER BY column)。
Hash索引
  • 特点
    • 基于哈希函数计算键值的位置。
    • 查找速度快,平均时间复杂度为O(1)。
    • 不支持范围查询和排序。
  • 适用场景
    • 等值查询(如 WHERE column = 'value')。
Bitmap索引
  • 特点
    • 使用位图表示数据的存在性。
    • 非常适合低基数列(如性别、状态等)。
    • 占用空间小,查询速度快。
  • 适用场景
    • 低基数列的查询。
R-Tree索引
  • 特点
    • 适用于多维空间数据。
    • 用于地理信息系统(GIS)中的空间查询。
  • 适用场景
    • 多维空间数据查询(如地图应用中的点、线、面查询)。
复合索引
  • 特点
    • 包含多个列的索引
    • 列的顺序非常重要,前导列的选择会影响查询性能。
  • 适用场景
    • 经常需要同时查询多个列的情况。
唯一索引
  • 特点
    • 确保索引列中的所有值都是唯一的。
    • 可以作为主键的一部分。
  • 适用场景
    • 需要保证列值唯一性的场景。
聚集索引与非聚集索引
  • 聚集索引
    • 决定了数据行的物理存储顺序。
    • 每个表只能有一个聚集索引
  • 非聚集索引
    • 不改变数据行的物理存储顺序。
    • 创建一个单独的数据结构来加速查询。
    • 每个表可以有多个非聚集索引

示例

假设我们有一个 employees 表,包含以下列:id, name, department_id, salary

CREATE TABLE employees (id INT PRIMARY KEY,name VARCHAR(100),department_id INT,salary DECIMAL(10, 2)
);
创建索引
  1. 单列索引

    CREATE INDEX idx_name ON employees(name);
    
  2. 复合索引

    CREATE INDEX idx_department_salary ON employees(department_id, salary);
    
  3. 唯一索引

    CREATE UNIQUE INDEX uidx_email ON employees(email);
    
  4. 聚集索引
    在MySQL中,主键默认是聚集索引

    ALTER TABLE employees ADD PRIMARY KEY (id);
    
  5. 非聚集索引

    CREATE INDEX idx_salary ON employees(salary);
    

注意

  • 索引虽然能加速数据检索,但也会消耗额外的磁盘空间,并降低写操作的性能(因为插入、删除和更新操作时需要同时修改表和索引)。
  • 在设计索引时,需要综合考虑数据的查询频率、修改频率、空间使用、数据分布等因素。

总结

索引是提高数据库查询性能的重要工具。根据不同的需求和场景选择合适的索引类型至关重要。在设计索引时,需要考虑以下几点:

  • 数据量大小
  • 查询模式(范围查询、等值查询等)
  • 更新频率
  • 存储空间

通过合理地设计和使用索引,可以显著提高应用程序的性能。


http://www.ppmy.cn/devtools/119276.html

相关文章

python 自动化测试接口

比如我们要测试接口:identity/chatRecords/pages 已在Postman中有,那我们就可以直接从里面复制出Python脚本 新建: pagerequest.py import requests import jsonurl "http://192.168.31.132:70/identity/chatRecords/pages"payl…

C++-第二章:引用、成员函数、inline函数和auto

目录 第一节:引用 1-1.引用的定义 1-2.引用的注意事项 1-3.引用的使用场景 1-4.引用和指针的联系 第二节:成员函数 第三节:面向过程与面向对象 第四节:inline函数 第五节:auto关键字 5-1.基本用法 5-2.使用场景 5…

【系统方案】智慧城市大数据平台建设方案(Word)

第1章 总体说明 1.1 建设背景 1.2 建设目标 1.3 项目建设主要内容 1.4 设计原则 第2章 对项目的理解 2.1 现状分析 2.2 业务需求分析 2.3 功能需求分析 第3章 大数据平台建设方案 3.1 大数据平台总体设计 3.2 大数据平台功能设计 3.3 平台应用 第4章 政策标准保障体系 4.1 政策…

MATLAB在无线通信系统测试与验证中的应用

在无线通信系统的设计与测试中,MATLAB提供了一套全面的解决方案,从系统建模到算法实现,再到物理层的测试与验证。本文将探讨MATLAB在无线通信系统测试与验证中的应用,包括信道建模、调制与解调、误码率分析、无线通信标准的实现以…

Java知识要点及面试题

Java知识要点 这份《服务端开发与面试知识手册》涵盖了Java后端开发的诸多领域,包括但不限于Java基础、JVM、多线程、MySQL、Redis、Spring、Spring Cloud、Kafka、分布式系统设计等。以下是关键要点和可能会被问到的面试题的总结: Java基础 关键要点…

LeetCode236题:二叉树的最近公共祖先

给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖…

PHP Session扩展默认session数据储存在哪里

PHP Session基础 PHP Session用于在用户访问网站的不同页面时保持用户状态。每当用户访问网站时,服务器可以为用户创建一个唯一的会话ID(Session ID),并通过该ID在用户与服务器之间传递信息。这些信息(即Session数据&…

Ubuntu20.04中ros2 foxy版本安装gazebo,并运行小车运动demo

这里默认你安装好了ros2 foxy版本 sudo apt install gazebo11sudo apt install ros-foxy-gazebo-ros-pkgs建议把其他的包也安装了 sudo apt install ros-foxy-gazebo-*安装速度的话,比安装ros环境快多了。 此时,可以在/opt/ros/foxy/share目录下看到若…