MySQL中的索引创建及应用

 更新时间:2026年01月22日 16:17:55   作者:极客编程坊  
文章介绍了MySQL中索引的概念、用途、弊端、应用场景以及创建、删除索引的方法,还详细讲解了索引的分类,包括逻辑应用维度、物理存储维度和数据存储结构维度,最后,文章还分析了MySQL中索引的存储结构,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧

MySQL中的索引应用

索引的定义

  • 什么是索引(Index)?

官方的定义索引是一种数据结构,从生活维度讲,假如将一本书看成是一张表,这本书的目录就是表中的索引.

  • 为什么要使用索引(Index)

数据量比较大时,为了快速找到们需要的数据可以使用索引,这样可以提高查询的效率.

  • 索引(Index)有什么弊端?
  1. 会额外的占用空间
  2. 对更新操作会带来一定的复杂度.
  • 使用索引(Index)的应用场景?
  1. on 子句
  2. where 子句
  3. group by 子句
  4. having 子句
  5. order by 子句

索引的分类

  • 逻辑应用维度 (主键,普通,联合,唯一,空间索引,…)
  • 物理存储维度 (聚簇索引,非聚簇索引)
  • 数据存储结构维度(hash,B+树,…)

索引创建及应用

  • 如何查看表中的索引?

show index from student;

  • 如何创建索引?
  1. 创建表的同时创建索引.(例如 create table tablename(…,index 索引名 (字段名)))
  2. 创建表后通过create语句创建索引(例如 create index 索引名 on 表名(字段名))
  3. 创建表后通过alter语句创建索引(例如 alter table add index 索引名(字段名))
  • 创建普通索引案例分享.
create index index_first_name on student(first_name);
alter table student add index index_last_name (last_name);
  • 创建唯一索引案例分享
create unique index index_first_name on student(first_name);
alter student add unique index index_first_name (last_name)
  • 创建组合索引案例分享
create index index_first_last on student(first_name,last_name);
alter table student add index index_first_last (first_name,last_name);
  • 如何删除索引?

drop index 索引名 on 表名;

例如

drop index index_first_last on student;

索引存储结构分析

  • MySQL中索引支持哪些存储结果?
  • hash,B+树,…
  • MySQL中InnoDB默认的索引存储结构是什么?
  • B+树
  • MySQL中的B+树有什么特点?
  1. 树中的非叶子节点只存储索引和指针
  2. 树中的叶子节点存储索引和数据
  3. 树中的叶子节点处于相同层,并且之间会使用双向链表连接,可以更好的支持范围查询.

  • MySQL中B+树相对于B树有什么优点?
  1. 一个磁盘可以存储索引数量会更多.
  2. 相同数据量的B+树相对于B树的高度相对会比较低(因为分叉多了)
  3. 叶子节点之间B+树有双向链表的连接,可以支持快速的范围查询.
  • 你觉得Hash索引有什么优势和劣势?
  • hash索引查询效率比较高,但是不支持范围查询.

聚簇索引和非聚簇索引

  • 什么是聚簇索引?

聚簇索引也叫聚集索引,索引和数据存储在一起,也就是索引与数据是不分离。
InnoDB存储引擎就是聚簇索引。

  • 聚簇索引都有哪些类型?

InnoDB中,一张表只有一个聚集索引(即主键索引),其他索引都是二级索引。
在实际应用中我们可以直接通过主键聚集索引查询到具体记录。假如是二级索引,这个
索引中存储是索引以及对应主键,我们使用二级索引执行查询时,是先基于二级索引找
到主键,再基于主键去查询具体记录(这个过程是回表查询)。

select first_name,salary
from employees
where employee_id=206

create index index_hire_date on employees(hire_date);
select first_name,salary,email
from employees
where hire_date='1987-07-09'

create index index_hire_date_salary on employees(hire_date,salary);
select first_name,salary,email
from employees
where hire_date='1987-07-09' and salary<8000
  • 什么是非聚簇索引?
    非聚簇索引是索引与数据是分离的,索引和数据是单独存储的。MyISAM存储引擎是非聚簇索引。

例如:

[10,0x1001] 0x1001表示记录地址
[12,0x1002]
0x1001 [10,Jack,J@t.com]
0x1002 [12,Mike,M@t.com]
  • 非聚簇索引存储的是什么?

非聚簇索引在创建时,存储的是索引值以及索引对应的记录的地址。
基于非聚簇索引查询数据时,可以先基于索引找到数据的一个地址,然后基于地址再去查找数据。
单从索引角度来说,非聚集索引查找速度不如聚集索引,非聚集索引找到索引位置后还需要根据索引找到数据对应的位置

到此这篇关于MySQL中的索引创建及应用的文章就介绍到这了,更多相关mysql索引应用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql数据库重置表主键id的实现

    mysql数据库重置表主键id的实现

    在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了解一下
    2025-03-03
  • 基于SQL中SET与SELECT赋值的区别详解

    基于SQL中SET与SELECT赋值的区别详解

    本篇文章是对SQL中SET与SELECT赋值的区别进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • 解决Access denied for user root @ 192.168.120.1 (using password: YES)的问题

    解决Access denied for user root @&nbs

    这篇文章给大家介绍了解决:Access denied for user ‘root‘@‘192.168.120.1‘ (using password: YES)的问题,文中通过图文和代码给大家分析的非常详细,具有一定的参考价值,需要的朋友可以参考下
    2024-01-01
  • mysql中的json查询过程

    mysql中的json查询过程

    在MySQL数据库中,进行JSON格式数据的查询时,需要使用特定函数和路径表达式来实现,本文给大家介绍mysql中的json查询过程,感兴趣的朋友一起看看吧
    2024-09-09
  • MySQL按时间进行表分区的方法代码

    MySQL按时间进行表分区的方法代码

    本文介绍如何在MySQL中创建按月份分区的表,并通过修改配置文件或使用数据库事件来实现自动分区,文中通过代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-09-09
  • MySQL如何匹配字符串函数

    MySQL如何匹配字符串函数

    MySQL提供多个字符串匹配函数,如like、locate、position、instr和find_in_set,其中locate、position、instr和find_in_set均返回字符在字段中的索引(如果包含),否则返回0,特别地,find_in_set适用于字段为数组的情况
    2024-11-11
  • MySQL 如何使用事务

    MySQL 如何使用事务

    这篇文章主要介绍了MySQL 如何使用事务,帮助大家更好的理解和学习MySQL数据库,感兴趣的朋友可以了解下
    2020-09-09
  • sql语句优化的一般步骤详解

    sql语句优化的一般步骤详解

    网上关于SQL优化的教程很多,但是比较杂乱,近日有空整理了一下,写出来跟大家分享,下面这篇文章主要给大家分享介绍了关于sql语句优化的一般步骤,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2017-09-09
  • MySQL报1366错误的原因及解决

    MySQL报1366错误的原因及解决

    SQL Error1366是一个常见的 MySQL 错误,主要成因是数据类型不匹配或数据超出了范围,本文主要介绍了MySQL报1366错误的原因及解决,感兴趣的可以了解一下
    2024-02-02
  • windows安装MySQL到D盘的超详细步骤

    windows安装MySQL到D盘的超详细步骤

    MySQL数据库作为关系型数据库中的佼佼者,因其体积小,速度快,成本低,不仅受到了市场的极大追捧,也受到了广大程序员的青睐,下面这篇文章主要给大家介绍了关于windows安装MySQL到D盘的超详细步骤,需要的朋友可以参考下
    2023-03-03

最新评论