MySQL数据库 - 索引

一. 索引的相关知识

1. 索引的概念

  • 是一个排序的列表,存储着索引值和这个值所对应的物理地址(类似于C语言的链表通过指针指向数据记录的内存地址)
  • 使用索引后可以不用扫描全表来定位某行的数据,而是先通过索引表找到该行数据对应的物理地址然后访问相应的数据,因此能加快数据库的查询速度
  • 是表中一列或者若干列值排序的方法
  • 需要额外的磁盘空间
  • 索引就好比是一本书的目录,可以根据目录中的页码快速找到所需的内容
  • 建立索引的目的是加快对表中记录的查找或排序

2. 索引的作用和副作用

2.1 作用

  • 数据库利用各种快速定位技术,能够大大加快查询速率,这是创建索引的最主要的原因
  • 当表很大或查询涉及到多个表时,可以成干上万倍地提高查询速度
  • 可以降低数据库的IO成本,并且还可以降低数据库的排序成本
  • 通过创建唯一性索引保证数据表数据的唯一性
  • 可以加快表与表之间的连接
  • 在使用分组和排序时,可大大减少分组和排序时间

2.2 副作用

  • 索引需要占用额外的磁盘空间。
    •  对于 MyISAM 引擎而言,索引文件和数据文件是分离的,索引文件用于保存数据记录的地址。而InnoDB引擎的表数据文件本身就是索引文件。当表很大或查询涉及到多个表时,可以成干上万倍地提高查询速度
  • 在插入和修改数据时要花费更多的时间,因为索引也要随之变动

2.3 知识拓展

MySQL 数据库的数据文件存放在/usr/local/mysql/data目录下,每个数据库对应一个子目录,用于存储数据表文件。每个数据表对应为三个文件,扩展名分别为“.frm”、“.MYD”和“.MYI”。

".MYD"文件是MyISAM存储引擎专用,存放MyISAM表的数据。每一个MyISAM表都会有一个“.MYD”文件与之对应,同样存放于所属数据库的文件夹下,和“.frm”文件在一起。

“.MYI”文件也是专属于 MyISAM 存储引擎的,主要存放 MyISAM 表的索引相关信息。对于 MyISAM 存储来说,可以被 cache 的内容主要就是来源于“.MYI”文件中。每一个MyISAM 表对应一个“.MYI”文件,存放于位置和“.frm”以及“.MYD”一样。

MyISAM 存储引擎的表在数据库中,每一个表都被存放为三个以表名命名的物理文件
(frm,myd,myi)。 每个表都有且仅有这样三个文件做为 MyISAM 存储类型的表的存储,也就是说不管这个表有多少个索引,都是存放在同一个.MYI 文件中。

另外还有“.ibd”和 ibdata 文件,这两种文件都是用来存放 Innodb 数据的,之所以有两种文件来存放 Innodb 的数据(包括索引),是因为 Innodb 的数据存储方式能够通过配置来决定是使用共享表空间存放存储数据,还是独享表空间存放存储数据。独享表空间存储 方式使用“.ibd”文件来存放数据,且每个表一个“.ibd”文件,文件存放在和 MyISAM 数据相同的位置。如果选用共享存储表空间来存放数据,则会使用 ibdata  文件来存放,所有表共同使用一个(或者多个,可自行配置)ibdata 文件。

3. 创建索引的原则依据

  • 表的主键、外键必须有索引
  • 记录数超过 300 行的表应该有索引
  • 经常与其他表进行连接的表,在连接字段上应该建立
  • 经常出现在where子句中的字段,特别是大表的字段应该建立索引
  • 索引应该建在选择性高的字段上
  • 索引唯一性太差的字段,不适合建立索引
  • 更新太频繁地字段,不适合创建索引
  • 索引应该建在小字段上,对于大的文本字段甚至超长字段,不要建索引

4. 数据结构上索引的分类

在数据结构的角度上,索引的分类并不统一,但从数据库管理系统(DBMS)的实现来看,我们可以归纳如下几种常见索引的数据结构:

B树(B-Tree)和B+树(B+Tree)

  • B树是一种自平衡的树数据结构,适合范围查询和点查询,广泛应用于磁盘上的文件系统以及数据库系统中。每个节点不仅存储键值,还存储对应的数据或者指向数据的指针。
  • B+树是B树的一个变体,叶子节点包含了所有的键值和对应的数据,非叶子节点仅存储键值,不保存数据。B+树更适合数据库索引,因为它在叶子节点之间形成了连续的链表,方便进行范围查询,并且索引本身只存储键值,减少了索引大小,提高内存利用率。

哈希索引(Hash Index)

哈希索引基于哈希表实现,能够实现O(1)的平均时间复杂度查找。哈希索引主要用于支持等值查询,但在不支持范围查询和排序操作时效率很高。

有序数组(Static Sorted Array)

对于静态且数据量较小的情况,有序数组可以作为高效的索引结构。但由于其插入和删除操作复杂度较高,一般不直接用于动态数据库场景。

LSM树(Log-Structured Merge Tree)

LSM 树是一种为了提高写入性能而设计的数据结构,广泛应用在很多NoSQL数据库系统中,比如LevelDB、RocksDB等。它通过批量合并和延迟排序的方式平衡读写性能。

Bitmap索引(BitMap Index)

位图索引适用于低基数(少量不同值)且频繁进行多值查询的场景。每个索引项对应一个bit位,通过位运算快速确定哪些记录满足查询条件。

R树(R-Tree)和R+树(R+Tree)

R树及其变种主要用于多维空间数据索引,如地理信息系统(GIS)中的空间查询。

全文索引(Full-text Index)

全文索引是对文本数据进行词语级别的索引,允许用户进行关键词的模糊查询和短语匹配。这类索引通常基于词典树(Trie)、倒排索引(Inverted Index)等结构实现。

组合索引(Composite/Index Covering)

组合索引不是特指某种数据结构,而是指在多个列上创建的索引,其内部可能结合了上述多种数据结构的特点。

5. 逻辑划分中索引的分类

从逻辑划分来看,索引的运用主要有五种,分别为:普通索引,唯一索引,主键索引,组合索引和全文索引(模糊索引) 

  • 普通索引(Basic Index):没有特殊限制,单纯为了加速查询速度。
  • 唯一索引(Unique Index):索引的键值必须唯一,除了加速查询外还能保证数据的唯一性。
  • 主键索引(Primary Key Index):特殊的唯一索引,每个表只能有一个,不允许为空,并决定了聚集索引的顺序。
  • 组合索引(单列索引与多列索引)
  • 全文索引(Full-text Index):针对文本列的特殊索引,用于对文本内容进行全文搜索。

二. 创建索引

创建测试用表,并导入数据。

2.1 普通索引的创建

最基本的索引类型,没有唯一性之类的限制。

2.1.1 直接创建索引

CREATE INDEX 索引名 ON 表名 (列名[(length)]);#(列名(length)):length是可选项。如果忽略 length 的值,则使用整个列的值作为索引。如果指定使用列前的 length 个字符来创建索引,这样有利于减小索引文件的大小。#索引名建议以“_index”结尾。

2.1.2 修改表方式创建

ALTER TABLE 表名 ADD INDEX 索引名 (列名);

2.1.3 创建表的时候指定索引

CREATE TABLE 表名 ( 字段1 数据类型,字段2 数据类型[,...],INDEX 索引名 (列名));

2.2 唯一索引

与普通索引类似,但区别是唯一索引列的每个值都唯一。
唯一索引允许有空值(注意和主键不同)。如果是用组合索引创建,则列值的组合必须唯一。添加唯一键将自动创建唯一索引。

2.2.1 直接创建唯一索引

CREATE UNIQUE INDEX 索引名 ON 表名(列名);

2.2.2 修改表方式创建

ALTER TABLE 表名 ADD UNIQUE 索引名 (列名);

2.2.3 创建表的时候指定

CREATE TABLE 表名 (字段1 数据类型,字段2 数据类型[,...],UNIQUE 索引名 (列名));

2.3 主键索引

是一种特殊的唯一索引,必须指定为“PRIMARY KEY”。
一个表只能有一个主键,不允许有空值。 添加主键将自动创建主键索引。

2.3.1 创建表的时候指定

CREATE TABLE 表名 ([...],PRIMARY KEY (列名));

2.3.2 修改表方式创建

ALTER TABLE 表名 ADD PRIMARY KEY (列名); 

2.4 组合索引

可以是单列上创建的索引,也可以是在多列上创建的索引。需要满足最左原则,因为 select 语句的 where条件是依次从左往右执行的,所以在使用 select 语句查询时where条件使用的字段顺序必须和组合索引中的排序一致,否则索引将不会生效。

CREATE TABLE 表名 (列名1 数据类型,列名2 数据类型,列名3 数据类型,INDEX 索引名 (列名1,列名2,列名3));

判断组合索引是否生效?

对以上的表进行select 
select name,id from pj04;			
#会触发组合索引而:
select id,name from pj04;			
#按照索引从左到右检索的顺序,则不会触发组合索引

2.5 全文索引

适合在进行模糊查询的时候使用,可用于在一篇文章中检索文本信息。
在 MySQL5.6 版本以前 FULLTEXT 索引仅可用于 MyISAM 引擎,在 5.6 版本之后 innodb 引擎也支持 FULLTEXT 索引。全文索引可以在 CHAR、VARCHAR 或者 TEXT 类型的列上创建。每个表只允许有一个全文索引。

2.5.1 直接创建索引

CREATE FULLTEXT INDEX 索引名 ON 表名 (列名);

2.5.2 修改表方式创建

ALTER TABLE 表名 ADD FULLTEXT 索引名 (列名);

2.5.3 创建表的时候指定索引

CREATE TABLE 表名 (字段1 数据类型[,...],FULLTEXT 索引名 (列名));##数据类型可以为 CHAR、VARCHAR 或者 TEXT

2.5.4 使用全文索引查询

select * from 表名  where 列名='查询内容';SELECT * FROM 表名 WHERE MATCH(列名) AGAINST('查询内容');

三. 查看索引和删除索引

1. 查看索引

show create table  表名;show index from 表名;
show index from 表名\G; 竖向显示表索引信息show keys from 表名;
show keys from 表名\G;


mysql> mysql> show index from test1;
+-------+------------+---------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| Table | Non_unique | Key_name      | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
+-------+------------+---------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| test1 |          0 | name_index    |            1 | name        | A         |           8 |     NULL | NULL   |      | BTREE      |         |               |
| test1 |          0 | cardid_index  |            1 | cardid      | A         |           8 |     NULL | NULL   | YES  | BTREE      |         |               |
| test1 |          1 | phone_index   |            1 | phone       | A         |           8 |     NULL | NULL   | YES  | BTREE      |         |               |
| test1 |          1 | address_index |            1 | address     | A         |           5 |     NULL | NULL   | YES  | BTREE      |         |               |
| test1 |          1 | remark_index  |            1 | remark      | NULL      |           8 |     NULL | NULL   | YES  | FULLTEXT   |         |               |
+-------+------------+---------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
5 rows in set (0.00 sec)

mysql> show keys from test1;
+-------+------------+---------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| Table | Non_unique | Key_name      | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
+-------+------------+---------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| test1 |          0 | name_index    |            1 | name        | A         |           8 |     NULL | NULL   |      | BTREE      |         |               |
| test1 |          0 | cardid_index  |            1 | cardid      | A         |           8 |     NULL | NULL   | YES  | BTREE      |         |               |
| test1 |          1 | phone_index   |            1 | phone       | A         |           8 |     NULL | NULL   | YES  | BTREE      |         |               |
| test1 |          1 | address_index |            1 | address     | A         |           5 |     NULL | NULL   | YES  | BTREE      |         |               |
| test1 |          1 | remark_index  |            1 | remark      | NULL      |           8 |     NULL | NULL   | YES  | FULLTEXT   |         |               |
+-------+------------+---------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
5 rows in set (0.00 sec)

各字段含义:

Table表的名称
Non_unique如果索引内容唯一,则为 0;如果可以不唯一,则为 1
Key_name索引的名称
Seq_in_index索引中的列序号,从 1 开始
Column_name列名称
Collation列以什么方式存储在索引中。在 MySQL 中,有值‘A’(升序)或 NULL(无分类)
Cardinality索引中唯一值数目的估计值
Sub_part如果列只是被部分地编入索引,则为被编入索引的字符的数目(zhangsan)。如果整列被编入索引,则为 NULL 
Packed指示关键字如何被压缩。如果没有被压缩,则为 NULL
Null如果列含有 NULL,则含有 YES。如果没有,则该列含有 NO
Index_type用过的索引方法(BTREE, FULLTEXT, HASH, RTREE)
Comment备注

2. 删除索引

2.1 直接删除索引

DROP INDEX 索引名 ON 表名;

2.2 修改表方式删除索引

ALTER TABLE 表名 DROP INDEX 索引名;

2.3 删除主键索引

ALTER TABLE 表名 DROP PRIMARY KEY;

总结:

① 普通索引 :针对所有字段,没有特殊的需求/规则
② 唯一索引 : 针对唯一性的字段,仅允许出现一次空值
③ 组合索引 (多列/多字段组合形式的索引)
④ 全文索引(varchar char text)MySQL为了优化对文本内容搜索的一种机制
⑤ 主键索引 :针对唯一性字段、且不可为空,同时一张表只允许包含一个主键索引

创建索引:
① 在创建表的时候,直接指定 index
② alter修改表结构的时候,进行add 添加index
③ 直接创建索引 index
PS:主键索引——》直接创建主键即可

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

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

相关文章

【Godot 3.5控件】用TextureProgress制作血条

说明 本文写自2022年11月13日-14日,内容基于Godot3.5。后续可能会进行向4.2版本的转化。 概述 之前基于ProgressBar创建过血条组件。它主要是基于修改StyleBoxFlat,好处是它几乎可以算是矢量的,体积小,所有东西都是样式信息&am…

基于Arduino IDE 野火ESP8266模块WIiFi开发

一、函数介绍 头文件 #include <ESP8266WiFi.h> #include <ESP8266WiFiMulti.h>ESP8266WiFi.h库主要用于连接单个WiFi网络。如果需要连接到多个WiFi网络&#xff0c;例如在需要切换不同网络或者备用网络时&#xff0c;可以使用ESP8266WiFiMulti.h头文件&#xff…

java.lang.String final

关于String不可变的问题&#xff1a;从毕业面试到现在&#xff0c;一个群里讨论的东西&#xff0c;反正码农面试啥都有&#xff0c;这也是我不咋喜欢面试代码&#xff0c;因为对于我而言&#xff0c;我并不喜欢这些面试。知道或不知道基本没啥含氧量&#xff0c;就是看看源代码…

【ZooKeeper】2、安装

本文基于 Apache ZooKeeper Release 3.7.0 版本书写 作于 2022年3月6日 14:22:11 转载请声明 下载zookeeper安装包 wget https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/zookeeper-3.7.0/apache-zookeeper-3.7.0-bin.tar.gz解压 tar -zxvf apache-zookeeper-3.7.0-b…

数据结构从入门到精通——二叉树的实现

二叉树的实现 前言一、二叉树链式结构的实现1.1前置说明1.2二叉树的手动创建 二、二叉树的遍历2.1 前序、中序以及后序遍历二叉树前序遍历二叉树中序遍历二叉树后序遍历2.2 层序遍历练习 三、二叉树的具体代码实现二叉树的节点个数二叉树叶子节点个数二叉树第k层节点个数二叉树…

个人网站制作 Part 14 添加网站分析工具 | Web开发项目

文章目录 &#x1f469;‍&#x1f4bb; 基础Web开发练手项目系列&#xff1a;个人网站制作&#x1f680; 添加网站分析工具&#x1f528;使用Google Analytics&#x1f527;步骤 1: 注册Google Analytics账户&#x1f527;步骤 2: 获取跟踪代码 &#x1f528;使用Vue.js&#…

实体框架EF(Entity Framework)简介

实体框架EF&#xff08;Entity Framework&#xff09;简介 文章目录 实体框架EF&#xff08;Entity Framework&#xff09;简介一、概述二、O/R Mapping是什么采用O/R Mapping带来哪些好处 三、Entity Framework架构3.1 下图展示了Entity Framework的整体架构3.2 Entity Framew…

MyBatis:XML操作

&#x1f451;专栏内容&#xff1a;MyBatis⛪个人主页&#xff1a;子夜的星的主页&#x1f495;座右铭&#xff1a;前路未远&#xff0c;步履不停 目录 一、MyBatis XML方式1、配置数据库2、指明XML路径3、写持久层代码 二、基础操作1、新增2、删除3、更新4、查找Ⅰ、开启驼峰命…

配置视图解析器

我们在指定视图的时候路径是有重复的&#xff0c;重复的操作可以用视图解析器&#xff0c;让框架帮我们&#xff1a; mv.setViewName("/WEB-INF/view/show.jsp");mv.setViewName("/WEB-INF/view/other.jsp"); 配置视图解析器&#xff1a; 注册视图解析器:帮…

202112青少年软件编程(Scratch图形化)等级考试试卷(三级)

第1题:【 单选题】 下列程序哪个可以实现: 按下空格键, 播放完音乐后说“你好! ” 2 秒? ( ) A: B: C: D: 【正确答案】: C 【试题解析】 : 第2题:【 单选题】 执行下列程序, 变量 N 的值不可能是? ( ) A:1 B:4 C:5 D:6 【正确答案】: D 【试题解析】…

制作一个RISC-V的操作系统六-bootstrap program(risv 引导程序)

文章目录 硬件基本概念qemu-virt地址映射系统引导CSR![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/86461c434e7f4b1b982afba7fad0256c.png)machine模式下的csr对应的csr指令csrrwcsrrs mhartid引导程序做的事情判断当前hart是不是第一个hart初始化栈跳转到c语言的…

分治法排序:原理与C语言实现

分治法排序&#xff1a;原理与C语言实现 一、分治法与归并排序概述二、归并排序的C语言实现三、归并排序的性能分析四、归并排序的优化 在计算机科学中&#xff0c;分治法是一种解决问题的策略&#xff0c;它将一个难以直接解决的大问题&#xff0c;分割成一些规模较小的相同问…

Expert Prompting-引导LLM成为杰出专家

ExpertPrompting: Instructing Large Language Models to be Distinguished Experts 如果适当设计提示&#xff0c;对齐的大型语言模型&#xff08;LLM&#xff09;的回答质量可以显著提高。在本文中&#xff0c;我们提出了ExpertPrompting&#xff0c;以激发LLM作为杰出专家回…

运动想象 (MI) 迁移学习系列 (14) : EEGNet-Fine tuning

运动想象迁移学习系列:EEGNet-Fine tuning 0. 引言1. 主要贡献2. 提出的方法2.1 EEGNet框架2.2 微调 3. 实验结果3.1 各模型整体分类结果3.2 算法复杂度比较3.3 不同微调方法比较 4. 总结欢迎来稿 论文地址&#xff1a;https://www.nature.com/articles/s41598-021-99114-1#cit…

【算法训练营】周测4

清华大学驭风计划课程链接 学堂在线 - 精品在线课程学习平台 (xuetangx.com) 如果需要答案代码可以私聊博主 有任何疑问或者问题&#xff0c;也欢迎私信博主&#xff0c;大家可以相互讨论交流哟~~ 考题11-4 题目描述 输入格式 从标准输入读入数据。 输入第一行为两个正整…

将main打包成jar;idea打包main为jar包运行

将main打包成jar&#xff1b;idea打包main为jar包运行 适用场景&#xff1a;可以封装一些小工具。 配置jar Maven中添加 <packaging>jar</packaging>将其打包为jar。 设置运行入口main 编译jar 看到jar输出 运行效果&#xff1a; 其中&#xff0c;三方依赖也被…

【Unity】获取游戏对象或组件的常用方法

前言 在Unity开发过程中&#xff0c;我们经常需要获取组件&#xff0c;那么在Unity里如何获取组件呢&#xff1f; 一、获取游戏对象 1.GameObject.Find GameObject.Find 是通过物体的名称获取对象的 所以会遍历当前整个场景&#xff0c;效率较低 而且只能获取激活状态的物体…

pytorch多层感知机

目录 1. 多层感知机2. 多层感知机loss梯度推导3. pytorch示例 1. 多层感知机 有多个输入节点、多个中间节点和多个输出节点 2. 多层感知机loss梯度推导 3. pytorch示例

MySQL 字段定义时的属性设置

开发的时候第一步就是建表&#xff0c;在创建表的时候&#xff0c;我们需要定义表的字段&#xff0c;每个字段都有一些属性&#xff0c;比如说是否为空&#xff0c;是否允许有默认值&#xff0c;是不是逐渐等。 这些约束字段的属性&#xff0c;可以让字段的值更符合我们的预期&…

HCIP—BGP路由聚合

在大型网络中&#xff0c;路由条目通常多达成千上万条&#xff0c;甚至几十万条&#xff0c;这给路由设备带来的挑战是&#xff1a;如何存储并有效管理如此众多的路由信息&#xff1f; BGP是一种无类路由协议&#xff0c;支持CIDR、VLSM和路由聚合。路由聚合技术的使用…