mysql索引作用的简单理解
转自:http://blog.csdn.net/pengsidong/article/details/62104703,有添加
索引好比书的目录,好比新华字典的拼音、偏旁部首查字,可以帮助人快速查找到需要的内容,
当数据表记录达到几十w级别的时候,索引的作用非常明显。
一、索引的类型
索引类型有多种,哈希、BTREE、全文索引等,其实不管什么类型,都是为了在特定业务场景下方便快速查找数据的算法。
例如哈希索引,key-value形式,最简单的,书本的目录也是类似的。
假如有一本书中,我们已知文章标题要找到这篇文章来阅读,如果没有目录,我们就要翻整本书去找标题,
但是如果标题单独抽出来作为key,页码作为value就可以快速找到内容。
显然书本开头的目录是要占用几页纸的,建立索引也是要消耗资源的。
BTREE索引是另一种算法,不同业务场景使用对应索引会更有效率。
就好比新华字典的目录跟普通的书本目录不同,新华字典可以通过拼音或者偏旁部首的查询方法去快速查到字在第几页,这也是一种“索引”
还有全文索引等,这里不在描述,例如solr、elasticsearch使用的算法可以去研究一下
二、怎么建索引
其实这个应该没有很明确的定义,只能根据具体业务去考虑。
1、索引不是越多越好,索引是要消耗资源的,有些字段信息不经常查询确建立索引反而影响效率。
就好像一本书如果把书中出现的人名、地名等都来建目录,目录可能占据整本书的1/3,而且读者常用的是文章标题目录,这样反而不好
2、相对来说表中经常查询使用的字段需要建立索引;
3、不要对经常变动的数据加索引,经常变化的字段添加索引反而降低性能;
4、小数据量的表建议不要加索引;
5、索引一般应该加在查找条件的字段;如:应加在where、order by子句中经常使用的字段
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)