当前位置: 首页 > article >正文

【数据库】【MySQL】索引

MySQL中索引的概念

索引(MySQL中也叫做"键(key)")是一种数据结构,用于存储引擎快速定找到记录。
简单来说,它类似于书籍的目录,通过索引可以快速找到对应的数据行,而无需遍历整个表。索引建立在表的列上,通过对列中的数据进行特定的排序和存储方式,使得数据库在执行查询操作时,能够迅速定位到满足条件的数据。例如,在一个包含大量用户信息的表中,如果没有索引,当要查询某个特定用户时,可能需要逐行检查每一条记录;而有了索引,数据库可以直接根据索引找到对应的用户记录,大大提高了查询效率。索引不仅可以用于加速查询,还能在数据唯一性约束、排序操作等方面发挥重要作用 。

索引的作用

  • 加快数据检索速度:通过索引可以快速定位到符合条件的数据行,减少全表扫描的次数,从而大大提高查询效率。
  • 在牺牲少量写入性能的前提下,显著提升查询效率
  • 唯一索引和主键索引能确保表中特定列的数据唯一性,避免重复数据的插入,保证数据的完整性。

索引的优缺点

优点

  • 提高查询速度,减少查询时间,提升数据库的响应性能。
  • 可以强制数据的唯一性,维护数据的完整性和一致性。

缺点

  • 占用存储空间:索引本身需要占用一定的磁盘空间,特别是在数据量较大的情况下,索引占用的空间也会相应增加。
  • 影响写入性能:在插入、更新和删除数据时,不仅要更新数据本身,还要更新对应的索引,会增加操作的时间和资源消耗。

MySQL中主流索引类型详解

索引有很多种不同的类型,可以为不同的场景提供更好的性能。在MySQL中,索引是在存储引擎层而不是在服务器层实现的。所以并没有同一的索引标准:不同存储引擎支持的索引不完全相同,不同的存储引擎相同索引的底层实现不一样,工作方式也不同。

核心索引类型对比

索引类型存储引擎支持数据结构是否唯一支持操作典型应用场景索引示例SQL
B+Tree索引InnoDB/MyISAMB+Tree可选=, >, <, >=, <=, BETWEEN, ORDER BY, LIKE ‘prefix%’主键索引、普通索引、联合索引CREATE INDEX idx_name ON users(last_name)
哈希索引MEMORY引擎显式支持
InnoDB自适应哈希隐式使用
Hash Table可选仅精确匹配 (=, <=>)内存表(MEMORY引擎)、等值过滤CREATE TABLE mem_table (...) ENGINE=MEMORY
全文索引InnoDB(5.6+)/MyISAM倒排索引不支持MATCH() AGAINST()
支持自然语言/布尔搜索
文章内容搜索、商品描述查询ALTER TABLE articles ADD FULLTEXT(title,body)
空间索引InnoDB(5.7+)/MyISAMR-Tree不支持GIS关系运算
(ST_Contains, ST_Distance等)
GIS数据查询、地图坐标查询、地理围栏判断CREATE SPATIAL INDEX sp_idx ON lands(poly)
主键索引所有引擎B+Tree强制唯一与B+Tree相同表的主标识字段CREATE TABLE ... PRIMARY KEY(id)

关注我!下一篇,我们继续详细学习不同类型的索引!


http://www.kler.cn/a/560942.html

相关文章:

  • STM32CUBEIDE FreeRTOS操作教程(十三):task api 任务访问函数
  • 目标检测之FAST RCNN论文简读
  • AIGC技术助力空军招飞,近屿智能开启智能人才培育新征程
  • SSTI知识点汇总
  • docker离线安装记录
  • Vulnhun靶机-kioptix level 4-sql注入万能密码拿到权限ssh连接利用mysql-udf漏洞提权
  • 05C语言——数组
  • 95.【C语言】解析预处理(3)
  • 【安装及调试旧版Chrome + 多版本环境测试全攻略】
  • [特殊字符] Elasticsearch 双剑合璧:HTTP API 与 Java API 实战整合指南
  • 塔能科技构建智慧隧道生态系统——城市升级改造的协同创新典范
  • 【Java项目】基于Spring Boot的简历系统
  • 电脑没声音了怎么恢复正常?一键恢复电脑声音
  • 使 Windows 呈现 macOS 风格的多功能桌面美化软件
  • 连锁管理系统的五大核心设计及 PHP 源码分享
  • 【深度解析:基于 C 语言实现含 IP 城市地址因素的抖音式简化推荐算法】
  • 2.2 STM32F103C8T6最小系统板的四种有关固件的开发方式
  • 超导量子计算机的最新进展:走向实用化的量子革命
  • 官方文档学习TArray数组的运算符
  • GaussDB会话超时参数与最大连接数设置