数据库(MySQL)—— 索引

数据库(MySQL)—— 索引

  • 什么是索引
  • 创建索引
      • 使用 `CREATE INDEX` 语句
      • 使用 `ALTER TABLE` 语句
      • 在创建表时定义索引
      • 特殊类型索引
      • 注意事项
  • 举个例子
  • 无索引的情况
  • 有索引的情况
  • 为什么索引快
  • 索引的结构

今天我们来看看MySQL中的索引

什么是索引

MySQL中的索引是一种数据结构,主要用于提高数据库查询效率。它类似于书籍的目录,让你能够快速找到所需内容而无需逐页浏览整本书。在数据库中,索引使得MySQL能够快速定位到表中特定数据行的位置,从而加速数据检索过程。

以下是关于MySQL索引的一些关键点:

  1. 数据结构:最常见的索引类型是B-Tree索引,它利用了平衡树的数据结构,保持数据排序,便于执行范围查询和排序操作。此外,还有哈希索引、全文索引等其他类型,分别适用于不同的查询需求。
  2. 存储位置:索引存储在数据库表的一个独立的结构中,不与实际数据混在一起。对于InnoDB存储引擎,聚簇索引(Clustered Index)会直接存储数据在叶子节点,而非聚簇索引(Secondary Index)则存储指向聚簇索引的指针。
  3. 提高查询速度:当执行查询时,数据库系统首先查看索引,直接定位到数据行,而不是遍历整个表,显著减少了查询时间,特别是在处理大数据量时。
  4. 索引选择:不是所有列都适合创建索引,一般在以下情况考虑创建索引:频繁作为查询条件的列、经常需要排序或分组的列、用于连接操作的列。但同时要注意,索引也会占用存储空间,并可能降低写入(插入、更新、删除)操作的性能,因为每次数据变更都需要同步更新索引。
  5. 复合索引:当一个索引包含多个列时,称为复合索引或多列索引。在复合索引中,最左侧原则是一个重要概念,即查询条件从索引的最左列开始进行匹配。但在MySQL 5.6及以上版本引入了索引下推功能,可以在一定程度上放宽这一限制。
  6. 管理索引:可以通过CREATE INDEX语句创建索引,使用ALTER TABLE语句添加或删除索引,以及使用DROP INDEX语句来删除索引。

综上所述,MySQL索引是优化数据库性能的关键工具,合理设计和使用索引对于提升应用的响应速度至关重要。

创建索引

在MySQL中,创建索引可以通过几种方式来实现,具体取决于你的需求和所使用的SQL语句。下面是几种常见的创建索引的方法:

使用 CREATE INDEX 语句

这是创建索引的最基本方式,适用于已存在的表。基本语法如下:

CREATE INDEX index_name ON table_name(column_name(length));
  • index_name 是你给索引指定的名字。
  • table_name 是你要在其上创建索引的表的名称。
  • column_name 是你想要索引的列名,可选的 (length) 指定索引的长度,仅对字符串类型列有效,可以减少索引大小但可能影响前缀匹配查询。

示例:

CREATE INDEX idx_lastname ON employees(lastname);

使用 ALTER TABLE 语句

如果你在创建表后想添加索引,也可以使用 ALTER TABLE 语句:

ALTER TABLE table_name ADD INDEX index_name(column_name);

或者,如果想创建唯一索引(不允许重复值):

ALTER TABLE table_name ADD UNIQUE INDEX index_name(column_name);

示例:

ALTER TABLE students ADD INDEX idx_email ON(email);

在创建表时定义索引

你也可以在创建表的同时定义索引:

CREATE TABLE table_name (column1 datatype,column2 datatype,...INDEX index_name(column_name),UNIQUE INDEX unique_index_name(column_name)
);

特殊类型索引

  • 全文索引:适用于全文本搜索。
CREATE FULLTEXT INDEX ft_index ON articles(content);
  • 空间索引:用于地理空间数据类型。
CREATE SPATIAL INDEX sp_index ON places(location);

注意事项

  • 在创建索引之前,应评估索引对查询性能的提升以及对数据插入、更新和删除操作的影响。
  • 避免对经常更新的列创建过多索引,因为这会增加维护索引的成本。
  • 使用 EXPLAIN 语句分析查询计划,以帮助决定最佳的索引策略。
  • 根据实际情况选择合适的索引类型,比如是否需要唯一索引、全文索引等。

通过上述方法,你可以根据数据库的具体需求灵活地创建不同类型的索引。

举个例子

我们创建一张表:

-- 学生表
CREATE TABLE stu(id int COMMENT '学生id',name varchar(10) COMMENT '姓名',tele_number varchar(11) COMMENT '电话号码'
)COMMENT '学生表';

我们插入一些数据:

-- 插入第一条学生记录
INSERT INTO stu (id, name, tele_number)
VALUES (1, '张三', '13800138000');-- 插入第二条学生记录
INSERT INTO stu (id, name, tele_number)
VALUES (2, '李四', '13912345678');-- 插入第三条学生记录
INSERT INTO stu (id, name, tele_number)
VALUES (3, '王五', '13777777777');-- 插入第四条学生记录
INSERT INTO stu (id, name, tele_number)
VALUES (4, '赵六', '13600000000');-- 插入第五条学生记录
INSERT INTO stu (id, name, tele_number)
VALUES (5, '陈七', '13555555555');-- 插入第六条学生记录
INSERT INTO stu (id, name, tele_number)
VALUES (6, '周八', '13411111111');-- 插入第七条学生记录
INSERT INTO stu (id, name, tele_number)
VALUES (7, '吴九', '13322222222');-- 插入第八条学生记录
INSERT INTO stu (id, name, tele_number)
VALUES (8, '郑十', '13233333333');-- 插入第九条学生记录
INSERT INTO stu (id, name, tele_number)
VALUES (9, '钱十一', '13144444444');-- 插入第十条学生记录
INSERT INTO stu (id, name, tele_number)
VALUES (10, '孙十二', '13055555555');

在这里插入图片描述

无索引的情况

我们执行下面的语句:

SET profiling = 1; -- 开启查询性能分析(MySQL特有)
SELECT SQL_NO_CACHE * FROM stu WHERE tele_number = '13800138000';
SHOW PROFILES; -- 显示最近的查询性能分析结果

找到下面的这条:
在这里插入图片描述
前面的时间就是执行查询语句的时间,我们看到时间是0.00022875秒。

当然,如果我们重复执行,每一次的时间都不一样,这个很正常。
在这里插入图片描述这次是0.00023775。

有索引的情况

我们对stu的tele_num创建索引:

CREATE INDEX idx_tele_number ON stu(tele_number);

然后,再执行上面的三句话:

SET profiling = 1; -- 开启查询性能分析(MySQL特有)
SELECT SQL_NO_CACHE * FROM stu WHERE tele_number = '13800138000';
SHOW PROFILES; -- 显示最近的查询性能分析结果

在这里插入图片描述
时间是0.000222,唉,时间好像没有节省很多哎。这里我们的数据比较少,看不出什么区别,如果数据量一旦很大,就可以看出索引的厉害了。

其实,索引的本质就是空间换时间,索引本身会占空间,但是通过索引我们可以提高检索速度。

为什么索引快

索引之所以快,是因为索引创建之后,数据的排序结构发生了变化(变成了索引结构)

如果没有索引,MySQL会进行全表查找:

在这里插入图片描述在无索引情况下,就需要从第一行开始扫描,一直扫描到最后一行,我们称之为 全表扫描,性能很低。

但是如果我们创建了索引,数据的排序结构就发生变化,比如变成二叉树:
在这里插入图片描述
此时我们在进行查询时,极大的提高的查询的效率。

索引的结构

索引的底层结构会有这几种:

索引类型结构描述
B+Tree索引最常见的索引类型,适用于大多数数据库引擎,如InnoDB。它通过层级的树状结构存储数据,每个节点可以包含多个键值对以及指向子节点的指针。叶子节点包含了实际的数据记录或数据记录的指针,并且叶子节点间通过指针相连,形成了一个有序链表,这有助于范围查询和排序操作。
Hash索引底层基于哈希表实现,适用于等值查询,特别是键值唯一或高度重复的情况。哈希索引通过计算索引列的哈希值并直接定位到对应的值或行,查询速度快。但由于哈希冲突的存在,它不支持范围查询,也无法用于排序或最左前缀匹配。
R-tree索引(空间索引)一种特殊类型的索引,主要由MyISAM引擎支持,用于高效地存储和查询多维空间数据,如地理坐标。R-tree通过将多维空间划分为重叠的区域来组织数据,使得空间查询(如“附近的所有地点”)变得高效。
Full-text索引(全文索引)专为文本内容设计的索引,能够支持复杂的文本搜索,包括词根搜索、同义词匹配等。它通过构建倒排索引来实现,即索引项是单词,而值是一系列包含该单词的文档位置。这种索引适用于大文本字段的模糊查询和全文搜索,常见于博客、文档数据库等应用场景。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/9052.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

财政部、交通运输部:推动北斗导航等新技术与交通基础设施融合

财政部、交通运输部:推动北斗导航等新技术与交通基础设施深度融合 近日,为深入贯彻落实中共中央、国务院关于加快建设交通强国、数字中国等决策部署,推进公路水路交通基础设施数字转型、智能升级、融合创新,加快发展新质生产力&a…

VisualGDB:Linux动态库项目创建、编译及库的使用

此篇接上篇 《VisualGDB:为Linux项目添加系统依赖库》,在本篇中我们重点分享一下如何基于VisualGDB 在VS中创建Linux动态库项目,如何编译及使用创建的动态库。 一、VisualGDB创建Linux动态库项目 如下,我们创建一个Linux下的动态库项目MyMath 二、编译动态库 我们稍微…

哈夫曼编码python算法实现(图片版)

一、问题: 请使用哈夫曼编码方法对给定的字符串,进行编码,以满足发送的编码总长度最小,且方便译码。“AABBCCDDEEABCDDCDBAEEAAA” 二、过程: 三、结果:

手动实现简易版RPC(四)

手动实现简易版RPC(四) 往期内容 手动实现简易版RPC(一):RPC简介及系统架构 手动实现简易版RPC(二):简单RPC框架实现 手动实现简易版RPC(三):mock数据生成 前言 接上几篇博客我们实现了最…

【6D位姿估计】FoundationPose 跑通demo 训练记录

前言 本文记录在FoundationPose中,跑通基于CAD模型为输入的demo,输出位姿信息,可视化结果。 然后分享NeRF物体重建部分的训练,以及RGBD图为输入的demo。 1、搭建环境 方案1:基于docker镜像(推荐&#xf…

重置密码之后无法ssh登录

背景描述 我这边有个服务器S,我从ServerA可以ssh上去,但是我从堡垒机B无法ssh上去;一开始以为是密码问题,手动重置密码,但是依然无法登录进去;一直提示密码错误;改了好几次密码都不行 问题原因…

5.9号模拟前端面试10问

5.9号模拟前端面试10问 1.html语义化的理解 HTML语义化是指使用具有明确含义的HTML标签来描述内容&#xff0c;而不仅仅是使用<div>和<span>等通用容器标签。语义化的HTML代码更易于阅读和维护&#xff0c;同时也有助于搜索引擎优化&#xff08;SEO&#xff09;。…

达梦数据库限制用户登录IP测试

达梦数据库创建用户时可以限制登录ip和时间段。 创建测试测试用户 create user test1 identified by Test_1234 ALLOW_IP "192.168.100.101"; 限定该用户只能通过192.168.100.101地址登录数据库 连接测试 上图可见&#xff0c;192.168.100.101客户端可以连接上19…

wish、亚马逊怎么给店铺引流?怎么运用自养号测评提高流量的转化率?

作为全球知名的跨境电商平台&#xff0c;wish、亚马逊为卖家提供了一个拓展海外市场的机会。然而&#xff0c;在wish、亚马逊平台上建立和经营一家成功的店铺需要有效的引流策略。那么&#xff0c;Wish、亚马逊怎样才能给店铺引流呢&#xff1f; 一、Wish、亚马逊怎么给店铺引…

C++学习笔记——仿函数

文章目录 仿函数——思维导图仿函数是什么仿函数的优势理解仿函数仿函数的原理举例 仿函数——思维导图 仿函数是什么 使用对象名调用operator&#xff08;&#xff09;函数看起来像是在使用函数一样&#xff0c;因此便有了仿函数的称呼&#xff1b;仿函数存在的意义是&#x…

javaMail快速部署——发邮件喽~

目录 功能阐述 前序步骤 &#xff08;1&#xff09;到QQ邮箱中获取到授权码 代码实现 坑 今天在写一个修改密码的功能的时候要用到邮箱的发送&#xff0c;然后因为这个项目比较老旧了&#xff0c;采用的是javaWeb和jsp的配置&#xff0c;对于我只使用过springBoot整合的ja…

苹果新款 M4 芯片专注于 AI

爆炸性消息&#xff01;苹果的新一代 M4 芯片来了&#xff01;这家伙拥有 38 万亿次操作的超强神经引擎&#xff0c;速度比苹果 A11 芯片的 NPU 快 60 倍&#xff01;虽然它的速度还没有达到 Snapdragon X Elite 的 45 TOPS&#xff0c;但苹果自夸 M4 将提供与最新 PC 芯片相同…

带你入门React

目录 前言一&#xff0c;基本配置1.1 环境搭建1.2 页面初始化渲染二&#xff0c;基础学习2.1 结构与样式开发2.2 数据展示2.3 行内样式2.4 条件渲染2.5 列表渲染2.6 点击事件 三&#xff0c;页面更新3.1 组件数据3.2 组件数据共享 总结 前言 笔者之前的工作经验都局限于Vue&am…

ICode国际青少年编程竞赛- Python-2级训练场-for循环中的变量

ICode国际青少年编程竞赛- Python-2级训练场-for循环中的变量 1、 for i in range(4):Dev.turnLeft()# 将i1作为Dev移动的步数Dev.step(i 1)2、 for i in range(4):Spaceship.step(i 1)Dev.step(3)Dev.step(-3)3、 for i in range(5):Dev.step(5 - i)Dev.turnRight()4、 …

开源文档管理系统Paperless-ngx如何在Linux系统运行并发布至公网

文章目录 1. 部署Paperless-ngx2. 本地访问Paperless-ngx3. Linux安装Cpolar4. 配置公网地址5. 远程访问6. 固定Cpolar公网地址7. 固定地址访问 Paperless-ngx是一个开源的文档管理系统&#xff0c;可以将物理文档转换成可搜索的在线档案&#xff0c;从而减少纸张的使用。它内置…

【Pytorch】1.读取训练数据集

导入Dataset类 from torch.utils.data import Dataset # 注意是Dataset&#xff08;大写&#xff09;的才是类通过jupyter我们可以阅读一下Dataset类的具体使用方法 help(Dataset) # 或者直接 Dataset??我们可以看到具体对Dataset类的解释 从蓝色字体我们可以得出 所有的代…

释放创造力,低成本实现您的梦想应用 —— 尽在我们的开源低代码平台!

在数字化时代&#xff0c;每个企业都渴望拥有自己的专属应用&#xff0c;但传统开发模式的高成本和技术壁垒让许多梦想搁浅。现在&#xff0c;我们为您带来了革命性的解决方案 —— 一个开源、免费、且功能强大的低代码开发平台&#xff01; 为什么选择我们的低代码平台&#…

QGraphicsView实现简易地图12『平移与偏移』

前文链接&#xff1a;QGraphicsView实现简易地图11『指定层级-定位坐标』 提供地图平移与偏移功能。地图平移是指将地图的中心点更改为给定的点&#xff0c;即移动地图到指定位置。地图偏移是指将当前视口内的地图向上/下/左/右/进行微调&#xff0c;这里偏移视口宽/高的四分之…

【ArcGIS 脚本工具】格式化简单渲染图层或图层组

CAD加GIS是规划人的黄金搭档&#xff0c;不可偏废。 小编通常直接在ArcPro中加载CAD查看&#xff0c;这样可以保证CAD修改之后GIS能同步更新显示。 但是CAD在ArcPro中的显示多少有点水土不服。 比如湘源地块在ArcPro3.0中显示时会自动加上透明度&#xff0c;虽然这样可以看到…

汇集全球顶级AI的自助平台

1、介绍:此平台以其开放和便捷的特性,为用户提供了一个无需月费的 AI 服务入口。咱可以根据自己的需求,灵活选择和付费使用平台上的 AI 技术。 该平台强调的核心优势在于 “零门槛” 和 “按需付费”,意味着用户不需要进行大额预付或者承担长期的固定费用,而是可以根据实际…