【MySQL】索引(下)

news2024/11/25 20:38:52

文章目录

  • 1. 普通索引
  • 2. 索引操作
    • 创建主键索引
    • 查询索引
    • 删除索引
    • 唯一索引的创建
    • 删除唯一键索引
    • 普通索引的创建
    • 全文索引

1. 普通索引

MySQL除了会默认建立主键索引,也可能会按照其他列信息建立的索引,一般这种索引称为 普通索引
对于 储存引擎 myisam,普通索引和主键索引是没有区别的


以第二列作为键值,构建B+树,可以发现 与主键构建的B+树基本没有区别
因为两者叶子节点都是存储 对应数据的地址


使用储存引擎以 innodb, 建立普通索引

依旧按照指定列作为键值,构建B+树
但是 由于 储存引擎 为 innodb , 所以 叶子节点存储 数据
此时叶子节点 存储的数据为 构建索引的键值 对应的主键值


(如果此时按照第三列构建索引,此时叶子节点 就会存储 对应第三列的主键值 )

2. 索引操作

创建主键索引

第一种方式
在创建表的时候,直接在字段名后 指定 primary key
create table user1(id int primary key );

第二种方式
在创建表的最后,指定某列或者某几列为主键索引
create table user2( id int, name varchar(20),primary key(id) );

第三种方式
创建表后再添加主键
create table use3(id int, name varchar(20));
alter table user3 add primary key(id);


查询索引

查询test1表,发现id是具有主键约束的


输入 show index from 表名; 查询索引
key_name表示索引名称为primary ,column_name 表示打在 id这一列上
index_type 表示 索引类型为 B+树


删除索引

输入 alter table 表名 drop pimay key; 删除对应的主键索引
此时发现test1表中的id 没有主键约束了


唯一索引的创建

第一种方式
在表定义时,在某列后直接指定unique唯一属性
create table user4( id int primary key, name varchar(20) unique);

第二种方式
创建表时,在表后面指定某列或某几列为 unique
create table user5(id int primary key, name varchar(20),unique(name));

第三种方式
在表创建好后,添加 某列为unique
create table user6(id int primary key ,name varchar(20));
zalter table user6 add unique(name);


以第三种方式为例,刚开始test1表中的name只是不为空,再对name添加唯一索引后
test1表 的 name 就有 唯一键 约束了


再次输入 show index from test1 \G 查看test1表的索引

key_name 表示 索引的名称
column_name 表示 索引以name为主
index_type 表示 索引的类型 为B+树


删除唯一键索引

alter table 表名 drop index 索引名;
索引名 是 show keys feom 表名中的 key_name 字段


输入 alter table test1 drop index name; 即可删除test1表中name 中的唯一键约束


普通索引的创建

第一种方式
create table user8(id int primary key,
name varchar(20),
email varchar(30),
index(name) –在表的定义最后,指定某列为索引
);


第二种方式
create table user9(id int primary key, name varchar(20), email
varchar(30));
alter table user9 add index(name); –创建完表以后指定某列为普通索引


输入 alter table test1 add index(name); 即将name变为普通索引


第三种方式
create table user10(id int primary key, name varchar(20), email
varchar(30));
create index idx_name on user10(name)– 创建一个索引名为 idx_name 的索引


输入 create table index myindex on test1(name);
在test1表中name列 创建一个索引名为 myindex 的索引


输入 show index from test1 \G 发现 key_name(索引的名称) 为 myindex


输入 alter table test1 drop index myindex; 就可以把myindex对应的索引名删除掉

全文索引

当对文章字段 或有大量文字的字段进行检索时,会使用到全文索引
若要使用全文索引,则要求表的储存引擎 为 MyISAM
并且默认的全文索引支持 英文,不支持中文

在表中添加 FULLTEXT ,让对应的列具有全文索引


创建一张表 articles ,内部包含 约束为 主键 并且 是自增长 的id 、200个字符 的title 、大文本的body
并将 title 和body 列 进行 全文索引


由于表中的id 是自增长的,所以只需插入 title 和 body 数据即可


输入 select * from articles; 查看当前表信息


想要在body列内容做搜索
如:查询articles表中 是否有 database 存在

输入 select * from articles where bidy like ‘database%’; 使用 like 进行模糊匹配 查询包含 database 及 带有后面的内容


使用 关键字 explain ,可以查看 是否使用索引

id 作为 这次请求的 id值,序号值 一般越大,越先执行
select_type 表示 查询类型 SIMPLE 表示 简单查询
table 表示 表名
type 表示 查询 方式 all 表示 全部遍历
key 表示 索引 NULL表示 没有使用索引查找


使用全文索引

输入 select * from articles where match(title,body) against(‘database’);
match 表示 设置条件
against 表示 匹配


再次使用 explain 查看是否使用索引

(type)遍历方式 为 使用全文索引(fulltext)
(key)索引 为 title ,表示使用 title 这个全文索引 进行查找

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

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

相关文章

Dubbo篇---第一篇

系列文章目录 文章目录 系列文章目录一、说说一次 Dubbo 服务请求流程?二、说说 Dubbo 工作原理三、Dubbo 支持哪些协议?一、说说一次 Dubbo 服务请求流程? 基本工作流程: 上图中角色说明: 二、说说 Dubbo 工作原理 工作原理分 10 层: 第一层:service 层,接口层,…

棱镜七彩兼容CCF版开源漏洞信息描述规范COSV Schema 1.0

CCF版开源漏洞信息描述规范COSV Schema 1.0(以下简称“COSV Schema1.0”)已于前期正式发布,棱镜七彩作为COSV Schema 1.0制定工作的重要成员积极响应规范内容,目前公司产品与漏洞推送服务已经实现COSV Schema 1.0兼容。 开源软件…

关于Linux下排查C++进程Segment fault问题的步骤

C 中出现Segment问题的常见原因有: 如果要定位Segment fault问题,需要进行如下几步: gdb your_program(gdb) break main(gdb) run(gdb) backtrace同时要在CMakeLists.txt文件中配置编译时启用符号调试信息, 在C或者C中的设置分别如下&#x…

Web APIs——M端事件、JS插件

1、M端事件 移动端也有自己独特的地方。比如触屏事件touch(也称触摸事件),Android 和 IOS都有。 触屏事件touch(也称触摸事件),Android和IOS都有。touch对象代表一个触摸点。触摸点可能是一根手指&#xff…

ChatGLM3设置角色和工具调用的解决方案

大家好,我是herosunly。985院校硕士毕业,现担任算法研究员一职,热衷于机器学习算法研究与应用。曾获得阿里云天池比赛第一名,CCF比赛第二名,科大讯飞比赛第三名。拥有多项发明专利。对机器学习和深度学习拥有自己独到的见解。曾经辅导过若干个非计算机专业的学生进入到算法…

Leetcode刷题详解——反转链表

1. 题目链接:206. 反转链表 2. 题目描述: 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 示例 1: 输入:head [1,2,3,4,5] 输出:[5,4,3,2,1]示例 2: 输入&#xff1…

word文章图片怎么缩小成200kb?看这篇攻略就够了

在编辑word文档的使用,常常会为了增加内容的丰富性去插入一些精美图片,不知道小伙伴有没有发现,其实我们导入的图片也是有大小限制的,如果图片过大就无法使用的,那么遇到这种情况该怎么处理呢?其实可以把图…

C++多态基础

文章目录 1.多态概念2.多态使用3.多态析构4.多态隐藏5.多态原理5.1.单类继承5.1.1.问题一:非指针或引用无法调用多态5.1.2.问题二:同类对象共用虚表5.1.3.问题三:子类对象拷贝父类对象虚表5.1.4.问题四:打印虚表地址和虚表内容 5.…

手写操作系统篇:实现裸机应用程序

文章目录 前言操作系统执行环境创建裸机平台项目Rust的Core库移除标准库依赖Qemu 启动流程内存布局编译流程内核的初始指令调整内核的内存布局手动加载内核可执行文件使用RustSBI提供的服务添加bootloader模块添加Makefile运行停止总体架构 前言 我们既然是手写操作系统&#…

峰回网关数采PLC

1.网络配置 例如:plc地址是192.168.1.56 1.访问网关 峰回网关默认网关地址 192.168.3.18,或者(10.10.253.354),本案例按照3.18讲解。 1和1相连,0和电脑相连 本地电脑修改ip为192.168.3.3(和3…

一分钟搞定!快速去除图片背景底色的步骤教程

最近不少小伙伴过来咨询,怎么样才能去除公章上的白色背景,一般电子公章很多都带有背景底色,使用起来非常不方便,所以今天就教大家一个不用ps就可以把图片转化透明底的方法,而且这是一款专业的在线ps工具;不…

SoftwareTest4 - 咋设计一个好的测试用例

咋设计一个好的测试用例 一 . 设计测试用例的万能公式功能测试性能测试界面测试兼容性测试易用性测试安全测试案例案例1 : 对水杯设计测试用例案例 2 : 对登录页面设计测试用例 二 . 具体设计测试用例的方法2.1 等价类等价类的概念等价类的用例编写 2.2 边界值2.3 判定表2.4 场…

docker部署MySQL服务

部署 MySQL8.0.35社区版 1.下载镜像 docker pull container-registry.oracle.com/mysql/community-server:8.0.35 查看镜像 docker images 2. 启动MySQL服务器实例 docker run --namemysql8 --restart on-failure -p 3309:3306 -d container-registry.oracle.com/mysql/comm…

2023-11-04 LeetCode每日一题(数组中两个数的最大异或值)

2023-11-04每日一题 一、题目编号 421. 数组中两个数的最大异或值二、题目链接 点击跳转到题目位置 三、题目描述 给你一个整数数组 nums &#xff0c;返回 nums[i] XOR nums[j] 的最大运算结果&#xff0c;其中 0 ≤ i ≤ j < n 。 示例 1&#xff1a; 示例 2&…

【项目管理】项目计划中常见影响进度的风险汇总

哈喽&#xff0c;大家好&#xff0c;我是雷工。 在项目实施过程中针对项目进度的计划常常会有各种各样的的风险&#xff0c;相比出了问题去救火与填坑&#xff0c;能够提前预知风险&#xff0c;并提前调整计划&#xff0c;更能有利于项目的如期交付。 以下为项目计划中影响进度…

周赛369(位运算、分类讨论、记忆化搜索==>动态规划、树形DP)

文章目录 周赛369[2917. 找出数组中的 K-or 值](https://leetcode.cn/problems/find-the-k-or-of-an-array/)位运算模拟 [2918. 数组的最小相等和](https://leetcode.cn/problems/minimum-equal-sum-of-two-arrays-after-replacing-zeros/)分类讨论 [2919. 使数组变美的最小增量…

计算机学院的老师们的实际编程能力如何?

计算机学院的老师们的实际编程能力如何&#xff1f; 国内的多数老师基本上就是学术界&#xff0c;工业界&#xff0c;教育界&#xff0c;这三个领域哪个他们都不沾边&#xff0c;几乎就是混日子&#xff0c;顺便能多混点钱就多混点钱的那种。 最近很多小伙伴找我&#xff0c;…

Day18力扣打卡

打卡记录 寻找重复数&#xff08;双指针&#xff09; 链接 Floyd判圈法&#xff0c;先用快慢指针以不同速率进行移动&#xff0c;最终一定会出现相遇点&#xff0c;然后在使一指针从初始开始&#xff0c;两指针再以同步调移动&#xff0c;再次相遇的点一定为循环开始的点位。 …

mysql 中!= 到底走不走索引?

mysql 中! 到底走不走索引&#xff1f; 很多人疑惑! 到底走不走索引&#xff0c; 这里可以肯定的说该操作是可以走索引的&#xff0c;但实际情况中都为啥都不走索引呢&#xff1f; 首先我们要知道走索引与数据量和数据趋势&#xff08;cardinality&#xff09;有很大的关系&…

用于比例方向控制阀的电控模块

比例方向控制阀电控放大器是一种电子装置&#xff0c;其主要功能是对弱电的控制信号进行整形、运算和功率放大&#xff0c;从而驱动比例方向控制阀。用于无位置传感器的比例方向控制阀。 通过控制PWM脉冲的占空比&#xff0c;可以控制比例阀端口的驱动电流&#xff0c;进而达到…