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

【数据库】【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)

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

相关文章:

  • SMT贴片代工高效解决方案
  • 建筑兔零基础自学python记录29|实战词云可视化项目——分人物阵营词云(上)7
  • 使用 Element Plus 的 `el-pagination` 组件与 Vue 3 实现分页功能
  • SQL:DQL数据查询语言以及系统函数(oracle)
  • <tauri><rust><GUI><PLC>基于tauri,编写一个串口调试助手
  • Android Audio其他——数字音频接口(附)
  • 如何用JAVA实现布隆过滤器?
  • git 的一些操作总结
  • 【入门音视频】音视频基础知识
  • java23种设计模式-工厂方法模式
  • 自学Linux系统软件编程七天
  • 【优选算法】四数之和
  • Python - 代码片段分享 - Excel 数据实时写入方法
  • 力扣LeetCode:1656 设计有序流
  • Python生成器250224
  • 代码随想录Day46 | 647.回文子串,516.最长回文子序列
  • CI/CD的定义
  • Docker 部署 Jenkins持续集成(CI)工具
  • 20250224-代码笔记02-class CVRPTrainer
  • 谈谈 ES 6.8 到 7.10 的功能变迁(3)- 查询方法篇
  • 深一度|有望冲击首轮秀?杨瀚森走出舒适圈站上大舞台
  • 最高法:政府信息公开案件审理应避免泄露国家秘密、商业秘密
  • 财政部:鼓励政策性银行对符合条件的城市更新项目提供支持
  • 益阳通报“河水颜色异常有死鱼”:未发现排污,原因待鉴定
  • 以开放促发展,以发展促开放,浙江加快建设高能级开放强省
  • 英国知名歌手批政府:让AI公司免费使用艺术家作品是盗窃