【MySQL】3.1MySQL索引的介绍

news2025/1/9 1:09:59

目录

一、索引的概念

数据库索引

索引的作用

索引的副作用

索引创建的原则(应用场景)

适合建立索引

二、索引的分类和创建

1.普通索引

创建普通索引

1.1直接创建

1.2修改表结构的方式创建普通索引

1.3创建表时创建普通索引

2.唯一索引

2.1直接创建唯一索引

2.2修改表结构的方式创建唯一索引

2.3创建表时创建唯一索引

3.主键索引

3.1修改表结构的方式创建主键索引

3.2创建表时创建主键索引

4.组合索引

4.1创建表时创建组合索引

5.全文索引

直接创建全文索引

修改表结构的方式创建全文索引

创建表时创建全文索引

使用全文索引查询

三、查看索引

各字段的含义

四、删除索引

直接删除索引

修改表的方式删除索引

删除主键索引

小结

创建索引

使用全文索引查询

查看索引

各字段的含义

删除索引

★★★


一、索引的概念

当并发量大且频繁时,可以做一个索引来减轻服务器负担(避免全局扫描)
索引相当于书籍的目录,能够帮助系统快速查找到想要的数据

数据库索引

        是一个排序的列表,存储着索引值和这个值所对应的物理地址
        无须对整个表进行扫描,通过物理地址就可以找到先要
        是表中一列或者若干列值的排序方法
        需要额外的磁盘空间来存储索引

索引的作用

当表的数据很多,或涉及到多个表时使用

        利用各种快速定位技术,能大大加快数据库的查询速度
        当表很大或查询涉及到多个表时,可以成千上万倍提高查询速度
        可以减低数据库的IO成本,和数据库的排序成本
        通过创建 唯一性 索引保证数据表中数据的唯一性
        在使用分组和排序时,可以大大减少分组和排序的时间

索引的副作用

        索引需要占用额外的磁盘空间
        在插入和修改数据时需要花费更多时间;因为数据更改时,索引也要随之变动

索引创建的原则(应用场景)

表的主键、外键必须有索引
记录的数据超过2万行的表应该有索引;没有索引的话,查询时就会把表遍历一遍,会严重影响数据库性能
经常与其他表进行连接的表,在连接字段上应该建立索引
经常出现在where子句中的字段,特别是大表字段,应该建立索引
    select 字段1,字段2 from 表名 where 字段x='';
索引应该建在选择性高的字段上

唯一性太差的字段不适合建立索引
更新太频繁的字段也不适合建立索引
索引应该建在小字段上,对于大的文本字段甚至超长字段不要建立索引
适合建立索引

1.小字段
2.唯一性强的字段
3.更新不频繁,单查询率高的字段
4.表记录超过2万
5.主键、外键、唯一键

二、索引的分类和创建

1.普通索引

最基本的索引;没有约束,能加快访问速度

创建普通索引
1.1直接创建
create index 索引名 on 表名(列名);
create index 索引名 on 表名(列名(length));

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

create index phone_index on test(phone);

1.2修改表结构的方式创建普通索引
alter table 表名 add index 索引名 (列名);
alter table test add index id_index (id);

1.3创建表时创建普通索引
create table 表名 (字段1,字段2,...,index 索引名(列名));
create table class (id int(3),name char(20),score decimal(5,2),index name_index(name));

2.唯一索引

与普通索引类似,但唯一索引列的值是唯一的

2.1直接创建唯一索引
create unique index 索引名 on 表名(列名);
create unique index phone_index on test(phone);

2.2修改表结构的方式创建唯一索引
alter table 表名 add unique 索引名 (列名);
alter table test add unique id_index (id);

2.3创建表时创建唯一索引
create table 表名 (字段1,字段2,...,unique 索引名 (列名));
create table class (id int,name char(10),score decimal(5,2),unique name_index(name));

3.主键索引

主键索引是一种特殊的唯一索引,必须指定为 "primary key"
一个表只能有一个主键,且不允许为空值;添加主键将自动创建主键索引

3.1修改表结构的方式创建主键索引
alter table 表名 add primary key(列名);
alter table test add primary key(id);

3.2创建表时创建主键索引
create table 表名 (字段1,字段2,...,primary key(列名));
create table class (id int,name char(10),score decimal(5,2),primary key(name));

4.组合索引

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

4.1创建表时创建组合索引
create table 表名 (列名1,列名2,...,index 索引名(列名1,列名2,列名3));
create table class (id int,name char(10),scorc decimal(5,2),phone int(11),index sum_index(id,name,phone));

​​​​​​​

5.全文索引

直接创建全文索引
create fulltext index 索引名 on 表名(列名);
create fulltext index full_index on test(address);

修改表结构的方式创建全文索引
alter table 表名 add fulltext 索引名 (列名);
alter table test add fulltext name_index(name);

创建表时创建全文索引
create table 表名 (列名1,列名2,...,fulltext 索引名(列名));
create table class (id int,name char(10),scorc decimal(5,2),phone int(11),fulltext name_index(name));

​​​​​​​

使用全文索引查询
select * from 表名 where match(列名) against('查询内容');
select * from test where match(name) against('lisi');

三、查看索引

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

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

各字段的含义

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

四、删除索引

直接删除索引

drop index 索引名 on 表名;
drop index sum_index on test;

修改表的方式删除索引

alter table 表名 drop index 索引名;

删除主键索引

alter table 表名 drop primary key;

小结

创建索引

创建普通索引
create index 索引名 on 表名(列名);
create index 索引名 on 表名(列名(length));
alter table 表名 add index 索引名 (列名);
create table 表名 (字段1,字段2,...,index 索引名(列名));

创建唯一索引
create unique index 索引名 on 表名(列名);
alter table 表名 add unique 索引名 (列名);
create table 表名 (字段1,字段2,...,unique 索引名 (列名));

创建主键索引
alter table 表名 add primary key(列名);
create table 表名 (字段1,字段2,...,primary key(列名));

创建组合索引
create table 表名 (列名1,列名2,...,index 索引名(列名1,列名2,列名3));

创建全文索引
create fulltext index 索引名 on 表名(列名);
alter table 表名 add fulltext 索引名 (列名);
create table 表名 (列名1,列名2,...,fulltext 索引名(列名));
使用全文索引查询
select * from 表名 where match(列名) against('查询内容');

查看索引

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

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

删除索引

drop index 索引名 on 表名;
alter table 表名 drop index 索引名;
alter table 表名 drop primary key;

★★★​​​​​​​

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

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

相关文章

ISO 8601:日期和时间的国际标准

ISO 8601 介绍 ISO 8601,介绍一下 ISO 8601 是由国际标准化组织(International Organization for Standardization,ISO)发布的国际标准,其全称为《数据存储和交换形式信息交换日期和时间的表示方法》。 这一标准提供了…

C语言 自定义类型:联合和枚举

目录 前言 一、联合体 1.1 联合体的特点 1.2 联合体与结构体的区别 1.3 联合体的大小计算 1.4 联合体例子 1.5 联合体判断大小端 二、枚举 2.1 枚举类型定义 2.2 枚举类型的优点 2.3 枚举类型的使用 总结 前言 之前我们讲了C语言其中一个自定义类型结构体&#xff…

jsp2024.3.21(4) html基础

一、实验目的 1、html 文件的基本结构&#xff1b; 2、html 的常用标记&#xff1b; <HTML> <HEAD> …… </HEAD> <BODY> …… </BODY> </HTML> 二、实验项目内容&#xff08;实验题目&#xff09; HTML常用标记 1&#xff0e;<…

说说你对webpack的理解?解决了什么问题?

文章目录 一、背景二、问题三、是什么参考文献 一、背景 Webpack 最初的目标是实现前端项目的模块化&#xff0c;旨在更高效地管理和维护项目中的每一个资源 模块化 最早的时候&#xff0c;我们会通过文件划分的形式实现模块化&#xff0c;也就是将每个功能及其相关状态数据各…

idea2023 运行多 springboot 实例

概要 1、修改idea运行多实例&#xff08;本地测试负载&#xff09; 你可能用到其他 1、改造项目缓存token 至redis 支持负载均衡部署 SpringSecurity6.0RedisJWTMP基于token认证功能开发&#xff08;源码级剖析可用于实际生产项目&#xff09;_springsecurity redis管理token…

【Django开发】前后端分离美多商城项目第3篇:用户部分,1. 后端接口设计:【附代码文档】

美多商城项目4.0文档完整教程&#xff08;附代码资料&#xff09;主要内容讲述&#xff1a;美多商城&#xff0c;项目准备1.B2B--企业对企业,2.C2C--个人对个人,3.B2C--企业对个人,4.C2B--个人对企业。项目准备&#xff0c;配置1. 修改settings/dev.py 文件中的路径信息,2. INS…

关于订单到期关闭的实现方案

前言 在电商、支付等系统中&#xff0c;一般都是先创建订单(支付单)&#xff0c;再给用户一定的时间进行支付&#xff0c;如果没有按时支付的话&#xff0c;就需要把之前的订单(支付单)取消掉。这种类似的场景有很多&#xff0c;还有比如到期自动收货、超时自动退款、下单后自…

API 接口渗透测试

1 API 接口介绍 1.1 RPC&#xff08;远程过程调用&#xff09; 远程过程调用&#xff08;英语&#xff1a;Remote Procedure Call&#xff0c;缩写为 RPC&#xff09;是一个计算机通信协议。该协议允许运行于一台计算机的程序调用另一台计算机的子程序&#xff0c;而程序员无…

爬虫分析-基于Python的空气质量数据分析与实践

概要 本篇文章利用了Python爬虫技术对空气质量网站的数据进行获取&#xff0c;获取之后把数据生成CSV格式的文件&#xff0c;然后再存入数据库方便保存。再从之前24小时的AQI&#xff08;空气质量指数&#xff09;的平均值中进行分析,把数据取出来后&#xff0c;对数据进行数据…

glibc内存管理ptmalloc

1、前言 今天想谈谈ptmalloc如何为应用程序分配释放内存的&#xff0c;基于以下几点原因才聊它&#xff1a; C/C 70%的问题是内存问题。了解一点分配器原理对解决应用程序内存问题肯定有帮助。C也在用ptmalloc. 当你在C中new一个对象时&#xff0c;底层还是依赖glibc中的ptma…

基于SpringBoot精品在线试题库系统

采用技术 基于SpringBoot精品在线试题库系统的设计与实现~ 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringBootMyBatis 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 页面展示效果 系统功能结构图 学生管理 教师管理 专业管理 试卷管理 …

【阿里魔搭】modelscope包下载安装

最终解决方案&#xff1a;使用源码安装modelscope 这里写目录标题 问题描述&#xff1a;pip安装包冲突安装步骤 问题描述&#xff1a;pip安装包冲突 一开始的是在3.11的虚拟环境下使用命令行pip install "modelscope[nlp]" -f https://modelscope.oss-cn-beijing.al…

基于时空上下文(STC)的运动目标跟踪算法,Matlab实现

博主简介&#xff1a; 专注、专一于Matlab图像处理学习、交流&#xff0c;matlab图像代码代做/项目合作可以联系&#xff08;QQ:3249726188&#xff09; 个人主页&#xff1a;Matlab_ImagePro-CSDN博客 原则&#xff1a;代码均由本人编写完成&#xff0c;非中介&#xff0c;提供…

MyBatis:XML操作

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

权限提升-Web权限提升篇划分获取资产服务后台系统数据库管理相互转移

知识点 1、权限提升转移-分类&高低&场景 2、Web权限提升及转移-后台&数据库 3、后台权限及转移-转移对象&后台分类 章节点&#xff1a; 1、Web权限提升及转移 2、系统权限提升及转移 3、宿主权限提升及转移 4、域控权限提升及转移 基础点 0、为什么我们要学…

Spring AI Embeddings 和 Vector 入门

在前面 Spring AI Chat 简单示例 中介绍了 Chat 的基本用法&#xff0c;本文在此基础&#xff08;主要是pom.xml&#xff09;上继续探索 Embedding 和 Vector。 官方文档&#xff1a; embeddings: https://docs.spring.io/spring-ai/reference/api/embeddings/openai-embedding…

java算法第30天 | ● 332.重新安排行程 ● 51. N皇后 ● 37. 解数独

今天是三道困难题&#xff0c;一刷可以先跳过。 332.重新安排行程 本题的重点是使用Map<String,Map<String,Integer>>存储路径以便递归中根据上一个地点检索接下来的选择。注意&#xff0c;因为要求按字母顺序排列优先级&#xff0c;所以内层的Map要用TreeMap<…

Jupyter Notebook介绍、安装及使用教程

Jupyter Notebook介绍、安装及使用教程 一、什么是Jupyter Notebook&#xff1f;简介组成部分网页应用文档Jupyter Notebook的主要特点 二、安装Jupyter Notebook先试用&#xff0c;再决定安装安装前提使用Anaconda安装使用pip命令安装 三、运行Jupyter Notebook帮助启动默认端…

html5cssjs代码 032 边框属性示例

html5&css&js代码 032 边框属性示例 一、代码二、解释 该HTML文件定义了一个网页页面&#xff0c;主要介绍了HTML5中CSS边框属性的用法。 一、代码 <!DOCTYPE html> <html lang"zh-cn"><head><title>编程笔记 html5&css&j…

图Graph及相关算法(Dijkstra,Kruskal)

目录 无向图 有向图 邻接矩阵 邻接表 图的bfs&#xff0c;dfs 二部图&#xff08;二分图&#xff09; 有向无环图&#xff08;DAG&#xff09; 拓扑排序&#xff08;Topological Sort&#xff09; AOV网 迪杰斯特拉Dijkstra 最小生成树 克鲁斯卡尔&#xff1a;Krus…