mysql索引概述

MySQL 的索引是一种数据结构,用于加快对数据库表中数据的检索速度。索引是存储在磁盘上的一种额外的数据结构,它包含着对数据库表中一列或多列的值进行排序的引用,以便快速查找数据。

1.索引的类型

1.1 普通索引(normal)

  • 普通索引是最基本的索引类型,在创建索引时不做任何特殊声明即为普通索引。
  • 普通索引允许表中出现重复的值,可以用于加速 SELECTUPDATEDELETE 查询语句的执行。

CREATE INDEX index_name ON table_name(column_name);

1.2 唯一索引(unique)

  • 唯一索引与普通索引类似,但是它要求索引列中的所有值都是唯一的,不允许重复。
  • 唯一索引可以用于强制表中的每一行具有唯一的值。

CREATE UNIQUE INDEX index_name ON table_name(column_name);

1.3 全文索引(full text)

  • 全文索引用于对文本数据进行全文搜索,例如 VARCHARTEXT 类型的列。
  • 全文索引允许对文本内容进行快速搜索,支持匹配自然语言中的词汇。

CREATE FULLTEXT INDEX index_name ON table_name(column_name);

1.4 空间索引(spatial)

  • 空间索引用于对空间数据进行搜索和分析,例如地理位置信息、几何数据等。
  • 空间索引可以加速对空间数据的查询和分析,支持空间数据的存储和检索。

CREATE SPATIAL INDEX index_name ON table_name(column_name);

2.索引方法

  • 这里的 BTREE 就是B+树索引
  • mysql默认创建的都是B+树索引

2.1 B树索引(B-tree Index):

  • B树索引是一种平衡树结构,通常用于实现数据库中的索引。
  • B树索引适用于范围查询和精确匹配查询,能够快速定位到特定值或范围内的数据。
  • B树索引的优点是适用于范围查询、支持高效的增删改查操作,适用于大部分数据库场景。
  • B树索引的缺点是对于大型数据集合和频繁的插入、删除操作,可能会导致索引分裂和性能下降。

2.2 B+树索引(B+tree Index):

  • B+树索引是B树索引的一种变种,具有更高的查询性能和更好的扩展性。
  • B+树索引在叶子节点上存储了所有数据,内部节点只存储索引值,这样可以减少IO操作,并且支持更大的数据容量。
  • B+树索引适用于范围查询、排序查询和覆盖查询,适用于大型数据库和频繁的查询操作。
  • B+树索引的缺点是相对于B树索引,对于单条记录的精确查找性能可能略低。

2.3 哈希索引(Hash Index):

  • 哈希索引是通过哈希函数将索引值映射到哈希表中的位置,从而实现快速定位。
  • 哈希索引适用于精确匹配查询,对于等值查询具有很高的查询性能。
  • 哈希索引的优点是查询性能高,对于大型数据集合和频繁的等值查询操作,性能较好。
  • 哈希索引的缺点是不支持范围查询和排序查询,而且对于查询中的模糊匹配(如LIKE查询)效果较差。
相关推荐
workflower1 小时前
FDD(Feature Driven Development)特征驱动开发
大数据·数据库·驱动开发·需求分析·个人开发
韩立学长1 小时前
基于Springboot的旧物公益捐赠管理系统3726v22v(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
苦学编程的谢2 小时前
Redis_4_常见命令(完)+认识数据类型和编码方式
数据库·redis·缓存
小光学长2 小时前
基于Vue的儿童手工创意店管理系统as8celp7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
小光学长2 小时前
基于Vue的地铁综合服务管理系统7949eg04(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
Yeats_Liao2 小时前
时序数据库系列(二):InfluxDB安装配置从零搭建
数据库·后端·时序数据库
Yeats_Liao2 小时前
时序数据库系列(一):InfluxDB入门指南核心概念详解
数据库·后端·时序数据库·db
betazhou3 小时前
Oracle ADG ,DGBroker管理,异常断电重启主备库的状态
数据库·oracle·goldengate·dgbroker
岁岁岁平安3 小时前
本机 MongoDB 注册系统服务、启用security认证
数据库·python·mongodb
007php0074 小时前
某游戏互联网大厂Java面试深度解析:Java基础与性能优化(一)
java·数据库·面试·职场和发展·性能优化·golang·php