【MySQL 一 数据库基础】深入解析 MySQL 的索引(3)

news2025/4/2 0:23:13

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述


索引


索引操作


自动创建


  • 当我们为一张表加主键约束(Primary key)外键约束(Foreign Key)唯一约束(Unique)时,MySQL会为对应的的列自动创建一个索引;
  • 如果表不指定任何约束时,MySQL会自动为每一列生成一个索引并用ROW_ID 进行标识,这个标识我们无法使用,是数据库内部生成的标识;
  • 建议为每一张表都定义一个主键,如果没有明确可以使用主键的列,我们可以在表多定义一个 bigint 类型的字段,然后使用自增主键来约束这个字段。

手动创建


(1) 主键索引

# 方式一,创建表时创建主键

create table t_test_pk (
	id bigint primary key auto_increment,
	name varchar(20)
);

# 方式二,创建表时单独指定主键列

create table t_test_pk1 (
	id bigint auto_increment,
	name varchar(20),
	primary key (id)
);

# 方式三,修改表中的列为主键索引

create table t_test_pk2(
	id bigint,
	name varchar(20)
);

# 修改表结构,为 id 列添加主键约束

alter table t_test_pk2 add primary key (id);

# 修改表结构,为 id 列修改为 bigint 类型且自增

alter table t_test_pk2 modify id bigint auto_increment;

(2) 唯一索引

# 方式一,创建表时创建唯一键

create table t_test_uk (
	id bigint primary key auto_increment,
	name varchar(20) unique
);

# 方式二,创建表时单独指定唯一列

create table t_test_uk1 (
	id bigint primary key auto_increment,
	name varchar(20),
	unique (name)
);

# 方式三,修改表中的列为唯一索引

create table t_test_uk2 (
	id bigint primary key auto_increment,
	name varchar(20)
);
alter table t_test_uk2 add unique (name);

(3) 普通索引

在这里插入图片描述

# 方式一,创建表时指定索引列

create table t_test_index (
	id bigint primary key auto_increment,
	name varchar(20) unique,
	sno varchar(10),
	index(sno)
);

# 方式二,修改表中的列为普通索引

create table t_test_index1 (
	id bigint primary key auto_increment,
	name varchar(20),
	sno varchar(10)
);
alter table t_test_index1 add index (sno);

# 方式三,单独创建索引并指定索引名(必须要指定名字),index_name 推荐使用表名+列名

create table t_test_index2(
	id bigint primary key auto_increment,
	name varchar(20),
	sno varchar(10)
);
create index index_name on t_test_index2(sno);

在这里插入图片描述


创建复合索引


# 方式一,创建表时指定索引列

create table t_test_index4(
	id bigint primary key auto_increment,
	name varchar(20),
	sno varchar(10),
	class_id bigint,
	index (sno,class_id)
);

在这里插入图片描述


# 方式二,修改表中的列为复合索引

create table t_test_index5(
	id bigint primary key auto_increment,
	name varchar(20),
	sno varchar(10),
	class_id bigint
);
alter table t_test_index5 add index (sno,class_id);

# 方式三,单独创建索引并指定索引名

create table t_test_index6 (
	id bigint primary key auto_increment,
	name varchar(20),
	sno varchar(10),
	class_id bigint
);
create index index_name on t_test_index6 (sno,class_id);

在这里插入图片描述


查看索引


# 方式一

show keys from table_name ;

# 方式二

show index from table_name ;

# 方式三,简要信息:desc 表名;

desc table_name ;

删除索引


主键索引

# 语法
alter table 表名 drop primary key;

# 示例,删除t_test_index6表中的主键

alter table t_test_index6 drop primary key;   # 删除主键不用指定列,因为一张表只有一个主键

在这里插入图片描述

# 如查提示由于自增列的错误,先删除自增属性,把自增列修改为非自增,再删除主键

alter table t_test_index6 modify id bigint;

alter table t_test_index6 drop primary key;

show keys from t_test_index6 ;  # 查看结果

其他索引

#语法

alter table 表名 drop index 索引名;

# 示例,删除t_test_index6表中名为index_name的索引

alter table t_test_index6 drop index index_name;

show keys from t_test_index6 ;

创建索引的注意事项


  • 索引应该创建在高频查询的列上

  • 索引需要占用额外的存储空间

  • 对表进行插入、更新和删除操作时,同时也会修索引,可能会影响性能

  • 创建过多或不合理的索引会导致性能下降,需要谨慎选择和规划索引


怎么查看自己写的SQL走没走索引


可以查看执行计划

# 构造测试表

create table student_index(
	student_id bigint primary key auto_increment ,
	sn varchar(6) unique ,
	name varchar(50) not null,
	mail varchar(50) ,
	class_id bigint ,
	index(class_id) 
);

insert into student_index values(1,1,1,1,1);

insert into student_index values(2,2,2,2,2);

# 创建 sn 和 name 的复合索引 

create index idx_student_sn_name on student_index(sn, name);

show index from student_index;

不加条件,查询所有

# 接下来,我们要判断下面这条 SQL 语句走不走索引

select* from student_index;

explain select* from student_index;

在这里插入图片描述


使用主键查询


# 加上查询条件

select* from student_index where student_id = 1;

explain select* from student_index where student_id = 1 ;

在这里插入图片描述


子查询中使用索引


select * from student_index where 
	student_id = (select student_id from student_index where student_id = 1);
	
explain select * from student_index where 
	student_id = (select student_id from student_index where student_id = 1);

在这里插入图片描述


使用普通索引


select * from student_index where sn = '1' ;

explain select * from student_index where sn = '1' ;  # sn 被 unique 约束

在这里插入图片描述


使用复合索引


# 删除 sn 列的单列索引 sn ,来演示复合索引 

alter table student_index drop index sn ;

select * from student_index where sn = '1' and name = '1';

explain select * from student_index where sn = '1' and name = '1';

在这里插入图片描述


select sn , name from student_index where sn = '1' and name = '1';

explain select sn , name from student_index where sn = '1' and name = '1';

在这里插入图片描述


如果条件包含了复合索引中的所有列,那么都会走索引,条件中的先后顺序不影响结果

explain select sn , name from student_index where  name = '1' and sn = '1';

在这里插入图片描述

我们创建的复合索引是 sn 在前,name 在后的;如果在查询中,先查 name ,再查 sn ,就类似于先查韵母,再查声母
这样虽然是不合理的,但是开发数据库的大佬为了保证健壮性,只要查询条件中,使用了索引包含的所有列,就会走索引,和顺序没有关系;


以 sn 为条件查询 name,这样的查询方法是合理的,走索引树查询(索引覆盖)

select name from student_index where sn = '1' ;

explain select name from student_index where sn = '1' ;

在这里插入图片描述


以 name 为条件查询 sn,这样的查询方法是不合理的,索引失去了意义,可能就会走全表查询

select sn from student_index where name = '1' ;

explain select sn from student_index where name = '1' ;

在这里插入图片描述


在这里插入图片描述

在这里插入图片描述

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

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

相关文章

【C++】优先级队列宝藏岛

> 🍃 本系列为初阶C的内容,如果感兴趣,欢迎订阅🚩 > 🎊个人主页:[小编的个人主页])小编的个人主页 > 🎀 🎉欢迎大家点赞👍收藏⭐文章 > ✌️ 🤞 &#x1…

List 接口中的 sort 和 forEach 方法

List 接口中的 sort 和 forEach 方法是 Java 8 引入的两个非常实用的函数,分别用于 排序 和 遍历 列表中的元素。以下是它们的详细介绍和用法: sort 函数 功能 对列表中的元素进行排序。 默认使用自然顺序(如数字从小到大,字符…

MusicGPT的本地化部署与远程调用:让你的Windows电脑成为AI音乐工作站

文章目录 前言1. 本地部署2. 使用方法介绍3. 内网穿透工具下载安装4. 配置公网地址5. 配置固定公网地址 前言 在如今快节奏的生活里,音乐不仅能够抚慰我们的心灵,还能激发无限创意。想象一下,在忙碌的工作间隙或闲暇时光中,只需输…

Unity通过Vosk实现离线语音识别方法

标注:deepseek直接生成,待验证 在Unity中实现离线语音识别可以通过集成第三方语音识别库来实现。以下是一个使用 Unity 和 Vosk(一个开源的离线语音识别库)的简单示例。 准备工作 Vosk:一个开源的离线语音识别库&am…

智能优化算法:莲花算法(Lotus flower algorithm,LFA)介绍,提供MATLAB代码

一、 莲花算法 1.1 算法原理 莲花算法(Lotus flower algorithm,LFA)是一种受自然启发的优化算法,其灵感来源于莲花的自清洁特性和授粉过程。莲花的自清洁特性,即所谓的“莲花效应”,是由其叶片表面的微纳…

企业数据集成:实现高效调拨出库自动化

调拨出库对接调出单-v:旺店通企业奇门数据集成到用友BIP 在企业信息化管理中,数据的高效流转和准确对接是实现业务流程自动化的关键。本文将分享一个实际案例,展示如何通过轻易云数据集成平台,将旺店通企业奇门的数据无缝集成到用…

数据库管理-第295期 IT架构与爆炸半径(20250221)

数据库管理295期 2025-02-21 数据库管理-第295期 架构与爆炸半径(20250221)1 术语新解2 硬件:存储VS本地盘3 数据库3.1 多模VS专用3.2 集中式VS分布式 4 公有云VS非公有云总结 数据库管理-第295期 架构与爆炸半径(20250221&#x…

基于WOA鲸鱼优化的BiLSTM双向长短期记忆网络序列预测算法matlab仿真,对比BiLSTM和LSTM

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 matlab2022a/matlab2024b 3.部分核心程序 (完整版代码包含详细中文注释和操作步骤视频…

DeepSeek私有化专家 | 云轴科技ZStack入选IDC中国生成式AI市场概览

DeepSeek 火爆全球AI生态圈,并引发企业用户大量私有化部署需求。 国际数据公司IDC近日发文《DeepSeek爆火的背后,大模型/生成式AI市场生态潜在影响引人关注》,认为中国市场DeepSeekAI模型的推出在大模型/生成式AI市场上引起了轰动&#xff0c…

npm在install时提示要安装python问题处理

使用npm\yarn\pnpm下载以来的时候,一直提示python异常,有的项目安装了python之后,下载依赖还是异常 而且旧版本项目使用python2,新的使用Python3…很烦 解决方案1:cnpm 安装教程: npm安装cnpm,解决node12\…

如何将MySQL数据库迁移至阿里云

将 MySQL 数据库迁移至阿里云可以通过几种不同的方法,具体选择哪种方式取决于你的数据库大小、数据复杂性以及对迁移速度的需求。阿里云提供了多种迁移工具和服务,本文将为你介绍几种常见的方法。 方法一:使用 阿里云数据库迁移服务 (DTS) 阿…

CSS基础(盒子模型的组成、内容溢出、隐藏元素的方式、样式的继承、元素的默认样式、布局技巧、元素之间的空白问题、行内块元素的幽灵空白问题)

文章目录 1. 盒子模型的组成1.1 内容区1.2 默认宽度1.3 内边距1.3.1 内边距属性1.3.2 复合属性1.3.3 单位1.3.4 注意事项 1.4 边框1.4.1 边框属性1.4.2 复合属性1.4.3 单方向边框1.4.4 边框样式1.4.5 注意事项 1.5 外边距1.5.1 外边距属性1.5.2 复合属性1.5.3 注意事项 1.6 外边…

【第二节】C++设计模式(创建型模式)-抽象工厂模式

目录 引言 一、抽象工厂模式概述 二、抽象工厂模式的应用 三、抽象工厂模式的适用场景 四、抽象工厂模式的优缺点 五、总结 引言 抽象工厂设计模式是一种创建型设计模式,旨在解决一系列相互依赖对象的创建问题。它与工厂方法模式密切相关,但在应用…

【开关电源】汽车前端电源保护电路设计

前言: 汽车电池端子在启动或者保养过程中被反接,如果对这些故障不能及时处理,就可能导致ECU或供电设备被损坏;此外在供电过程中电压也存在不稳定的情况。在EMC测试中ISO16750和ISO7637也会有负电压的情况。 肖特基二极管和 P 沟道…

网络运维学习笔记 017 HCIA-Datacom综合实验01

文章目录 综合实验1实验需求总部特性 分支8分支9 配置一、 基本配置(IP二层VLAN链路聚合)ACC_SWSW-S1SW-S2SW-Ser1SW-CoreSW8SW9DHCPISPGW 二、 单臂路由GW 三、 vlanifSW8SW9 四、 OSPFSW8SW9GW 五、 DHCPDHCPGW 六、 NAT缺省路由GW 七、 HTTPGW 综合实…

C++单例模板类,继承及使用

前言: 单例模式可以参考如下文章: 我的设计模式,单例模式的设计和实现 c 单例模式的模板类 - 川野散人 - 博客园 1.为什么需要单例模板类? 场景问题: 如果需要100个单例类就需要设计100个单例模式,代…

nodejs:vue 3 + vite 作为前端,将 html 填入<iframe>,在线查询英汉词典

向 doubao.com/chat/ 提问: node.js js-mdict 作为后端,vue 3 vite 作为前端,编写在线查询英汉词典 后端部分(express js-mdict ) 详见上一篇:nodejs:express js-mdict 作为后端&#xff…

现场可以通过手机或者pad实时拍照上传到大屏幕的照片墙现场大屏电子照片墙功能

现场可以通过手机或者pad实时拍照上传到大屏幕的照片墙现场大屏电子照片墙功能,每个人都可以通过手机实时拍照上传到大屏幕上,同时还可以发布留言内容,屏幕上会同步滚动播放展示所有人的照片和留言。相比校传统的照片直播功能更加灵活方便,而…

《FFTformer:基于频域的高效Transformer用于高质量图像去模糊》

paper:2211.12250 GitHub:kkkls/FFTformer: [CVPR 2023] Effcient Frequence Domain-based Transformer for High-Quality Image Deblurring CVPR 2023 目录 摘要 1、介绍 2、相关工作 2.1 基于深度CNN的图像去模糊方法 2.2 Transformer及其在图…

ChātGPT赋能的“SolidWorks工具箱”:重塑3D设计效率新标杆

ChātGPT精心打造的“SolidWorks工具箱”正逐步成为3D设计领域中的一颗璀璨新星,其集高效、便捷与创新于一身,为用户带来了前所未有的设计体验。以下是对这一革命性工具箱的深度剖析与美化呈现: 一、核心功能:重塑设计流程&#x…