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

MYSQL索引篇--基础知识

索引:索引的出现其实就是为了提高数据库的查询效率,就像书的目录一样。

MYSQL在查询方面主要就是两种方式:全表扫描和根据索引检索

索引的基本操作

创建索引

create index 索引名 on 表名

删除索引

drop index 索引名 on 表名

查看一个SQL语句是否使用了索引进行检索

在SQL语句前 添加explian关键字

  • type=ALL时,表示使用 全表查询(未使用索引)

  • type=RES时,表示使用索引

索引有哪些类别

按数据结构分类:B+tree索引,Hash索引,Full-text索引

InnoDB 是在 MySQL 5.5 之后成为默认的 MySQL 存储引擎,B+Tree 索引类型也是 MySQL 存储引擎采用最多的索引类型。

在创建表时,InnoDB 存储引擎会根据不同的场景选择不同的列作为索引:

• 如果有主键,默认会使用主键作为聚簇索引的索引键(key);
• 如果没有主键,就选择第一个不包含 NULL 值的唯一列作为聚簇索引的索引键(key);
• 在上面两个都没有的情况下,InnoDB 将自动生成一个隐式自增 id 列作为聚簇索引的索引键(key);

其它索引都属于辅助索引(Secondary Index),也被称为二级索引或非聚簇索引。创建的主键索引和二级索引默认使用的是 B+Tree 索引。

按物理储存分类聚簇索引(主键索引)、二级索引(辅助索引)

InnoDB 是在 MySQL 5.5 之后成为默认的 MySQL 存储引擎,B+Tree 索引类型也是 MySQL 存储引擎采用最多的索引类型。

在创建表时,InnoDB 存储引擎会根据不同的场景选择不同的列作为索引:

• 如果有主键,默认会使用主键作为聚簇索引的索引键(key);
• 如果没有主键,就选择第一个不包含 NULL 值的唯一列作为聚簇索引的索引键(key);
• 在上面两个都没有的情况下,InnoDB 将自动生成一个隐式自增 id 列作为聚簇索引的索引键(key);

其它索引都属于辅助索引(Secondary Index),也被称为二级索引或非聚簇索引。创建的主键索引和二级索引默认使用的是 B+Tree 索引。

按字段特性分类:主键索引,唯一索引,普通索引,前缀索引。

主键索引

主键索引就是建立在主键字段上的索引,通常在创建表的时候一起创建,一张表最多只有一个主键索引,索引列的值不允许有空值。

在创建表时,创建主键索引的方式如下:

create table table_name( .... PRIMARY KEY(index_column_1) USING BTREE );
唯一索引

唯一索引建立在 UNIQUE 字段上的索引,一张表可以有多个唯一索引,索引列的值必须唯一,但是允许有空值。

在创建表时,创建唯一索引的方式如下:

CREATE TABLE table_name( .... UNIQUE KEY(index_column_1,index_column_2,...) );

建表后创建唯一索引,可以用下面的语句:

CREATE UNIQUE INDEX index_name ON table_name(index_column_1,index_column_2,...);
普通索引

普通索引建立在普通字段的索引,不要求字段为主键,也不要求字段为unique.

在创建表时,创建普通索引的方式如下:

CREATE TABLE table_name( .... INDEX(index_column_1,index_column_2,...) );

建表后创建普通索引,可以用下面的语句:

CREATE INDEX index_name ON table_name(index_column_1,index_column_2,...);
前缀索引

前缀索引是指对字符类型字段的前几个字符建立的索引,而不是在整个字段上建立的索引,前缀索引可以建立在字段类型为 char、 varchar、binary、varbinary 的列上。

使用前缀索引的目的是为了减少索引占用的存储空间,提升查询效率。

在创建表时,创建普通索引的方式如下:

CREATE TABLE table_name( column_list, INDEX(column_name(length)) );

建表后创建普通索引,可以用下面的语句:

CREATE INDEX index_name ON table_name(column_name(length));

按字段个数分类:单列索引,联合索引。

索引区分度:索引区分度表示某个字段不同值得个数占整个表的比列建立联合索引时,要把区分度大的字段排在前面。

索引的优缺点

优点:

  • 使用索引可以大大加快数据的检索速度(大大减少检索的数据量),这也是创建索引的最主要的原因。
  • 但是注意使用索引不一定能够提高查询性能,因为如果数据库的数据量不大,那么使用索引也不一定能够带来很大提升。其余大多数情况下,索引查询比全表扫描要快。
  • 通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。

缺点:

  • 空间消耗,一个索引对应的就是一棵 B+树,每一个节点都是一个 16KB 大小的页。占用的空间较大

  • 创建索引和维护索引需要耗费许多时间,当对表中的数据进行增删改的时候,如果数据有索引,那么索引也需要动态的修改,会降低 SQL 执行效率。

创建索引的场景

  • 频繁用于查询的列需要创建索引
  • 大表:对于很大的表,建立索引可以提高查询速度
  • 唯一性要求:主键列和唯一性约束的列会自动创建唯一索引,但如果查询中经常包含唯一性条件,可以额外创建唯一性索引。
  • 连接表的外键列:为外键列创建索引可以提高连接的效率。
  • 频繁使用排序和分组的列:如果某列经常用于 ORDER BY 或 GROUP BY 子句可以创建索引

不创建索引的场景

  • 小表:在小表上,索引不会带来显著的性能提升,还会增加维护开销。
  • 经常进行更新的字段不需要创建索引
  • 很少用于查询的字段
  • 字段中存在大量重复数据,不需要创建索引,比如性别字段

索引优化的方法

  • 前缀索引优化:使用某个字段中字符串的前几个字符建立索引,从而减小索引字段大小

  • 覆盖索引优化:从二级索引中可以查询得到记录,避免回表

  • 主键索引最好是自增的;这样每次插入一条新记录,都是追加操作,不需要重新移动数据,而使用非自增主键会导致插入主键的索引值是随机的,这可能会插入到现有数据页的某个位置,导致其他数据的移动,造成页分裂。

  • 避免过多的索引

http://www.jsqmd.com/news/183780/

相关文章:

  • hot100-63买卖股票的最佳时机
  • GRNN广义回归神经网络分类预测+特征贡献SHAP分析+特征依赖图!Matlab代码
  • AI药品管理系统:用技术筑牢医药全链路安全防线
  • Vue 3 Watch 进阶指南:从基础进阶到 Vue 3.5 新特性全掌握
  • 科研写作智能化:9款AI工具深度解析,高效生成开题报告与论文初稿
  • 学术写作进入AI时代:9款智能工具实测,开题报告与论文初稿速成指南
  • 吐血推荐专科生必用9款AI论文软件
  • LeetCode 63:Unique Paths II - 带障碍网格路径问题的完整解析与面试技巧
  • AI革新学术写作方式,9款精选智能工具实现论文高效产出
  • OCSSA-VMD-Transformer-LSTM-Adaboost轴承故障诊断MATLAB代码实现
  • 科沃斯x11pro的优缺点
  • 技术文章大纲:Anaconda加速AI模型训练
  • 2026广东厨师中式烹调师报考学校排名及职业认证机构培训课程推荐白皮书 - 品牌企业推荐师(官方)
  • 9款AI写作工具横评:学术研究从开题到初稿的智能化解决方案
  • AI应用架构师实战:体育行业AI赛事决策系统的架构设计
  • IDM插件开发创意赛技术文章大纲
  • 2026年广东保育师认证机构课程推荐与优质培训学校综合排名白皮书 - 品牌企业推荐师(官方)
  • CSDN官网热议:VoxCPM-1.5-TTS-WEB-UI是否将颠覆传统语音合成方式?
  • 学术写作迎来智能化突破,9款AI工具实测加速开题与论文创作
  • 2026年广东健康管理师培训学校排名与认证机构课程推荐白皮书 - 品牌企业推荐师(官方)
  • AI驱动学术写作升级,9款精选工具提供从构思到成稿的全流程支持
  • blender 开放exec接口的插件
  • D. Interval Cubing
  • 学霸同款10个AI论文写作软件,助你轻松搞定本科论文!
  • 把IP地址转换为字符串
  • BKA-Transformer-LSTM多变量时间序列预测Matlab实现
  • AI技术正在重塑学术写作,精选9款工具评测为研究提供智能化支持
  • 基于空间矢量控制的永磁同步电机状态反馈控制转速系统设计及仿真(含仿真平台、设计文档及高清仿真结果)”
  • 一次讲透 !、、||:90% 的条件判断 Bug 都出在这里
  • 餐厅菜单语音化:顾客扫描二维码听取VoxCPM-1.5-TTS-WEB-UI菜品介绍