*MYSQL--索引*

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: *MYSQL--索引*

一:介绍

       在MYSQL当中,索引的使用类似于书当中目录的作用,索引的使用能够让查询更加的迅速,比方说搜索mysql这个单词的时候,可以先从首字母为m开头的字母进行查找,这样就大大减少了搜索的时间,而不是从头到尾进行搜索,提高查询的速度


二:类型

主要分为两大类,一种是根据底层的结构进行区分的(HASH索引,和B-TREE索引),另外一种是根据功能进行区分的;


1.按照底层数据结构区分

       1>HASH索引:

       HASH索引实际上是根据哈希表的一种索引结构,通过在刚开始的时候,将索引列的值通过哈希算法(f())的方式,将其转化为哈希值.之后如果需要查找,再通过这个哈希值进行查找即可

  2>BTREE索引:

       一种树形结构的索引,从上(树根)往下(分支)不断缩小范围进行相应的查找


       2.按照功能进行区分

       1>单列索引:

               ①普通索引

               ②唯一索引

               ③主键索引

 2>组合索引

       3>全文索引

       4>空间索引


三:依据功能区分讲解:

 1.单列索引(仅仅只包含一个列,但是一个表当中可以有多个的单列索引):

       1>普通索引:

       Ⅰ介绍.

       MYSQL当中最基本的索引类型,无限制,允许在定义索引的列种加入空值以及重复值,仅仅是为了加快查询速度

     Ⅱ 操作.
  添加方式一:直接在创建表的时候添加索引
  create table emp1(
  id int,
  name VARCHAR(20),
  salary int,
  INDEX index_id(id)  
  );
  
  添加方式二:创建表之后进行直接添加
  create index indexname on tablename(columnname);
  create index index_salary on emp1(salary);
  
  添加方式三:通过修改表结构进行添加索引   -- 推荐
  alter table tablename add index indexname(columnname);
  alter table emp1 add index index_name(name);
  
  
  
  删除索引操作:
  一:drop index 索引名 on 表名
  二:alter table 表明 drop index 索引名

 2>唯一索引:

       Ⅰ 介绍:

       唯一索引跟普通索引相似,仅仅只有在本索引列上,数值必须是不同的,也可以有空值,但是如果是组合索引,列值的组合必须是唯一的

       Ⅱ 操作:
-- 单列索引
  添加方式一:
    create table emp1(
  id int,
  name VARCHAR(20),
  salary int,
  unique index_id(id)  
  );
  
    添加方式二:创建表之后进行直接添加
  create unique index indexname on tablename(columnname);
  create unique index index_salary on emp1(salary);
  
  添加方式三:通过修改表结构进行添加索引   -- 推荐
  alter table tablename add unique index indexname(columnname);
  alter table emp1 add unique index index_name(name);
  
  
  删除方式:
  一:drop index 索引名 on 表名
  二:alter table 表明 drop index 索引名
  
  alter table emp1 drop index index_salary; 
  alter table emp1 drop index index_id; 

 3>主键索引 :

       Ⅰ 介绍:

       主键索引,顾名思义,在创建表的时候,针对某一个列添加的主键之后,系统会自动对其添加主键索引(PRIMARY KEY) 主键索引不允许出现重复值以及NULL值

       2.组合索引:

  1>介绍:

               组合索引也叫做是复合索引,指的是在建立索引的时候使用了多个的字段.比如使用ID和姓名一起建立索引,同样的可以设置是复合普通索引,还是复合唯一索引

               2>操作:

组合索引:
  组合索引也叫做是复合索引,指的是在建立索引的时候使用了多个的字段.比如使用ID和姓名一起建立索引,同样的可以设置是普通索引,还是唯一索引
  
  语法:复合普通索引
  create index indexname on tablename(name1,name2....);
  
  create index index_id_name on emp1(id,name);
  
  语法:创建唯一索引
  create unique index indexname on tablename(name1,name2);
  
  create unique index index_id_name on emp1(id,name);
  
  索引的删除:
  alter table tablename drop index indexname;

    3>TIPS:

               1.需要注意的是,如果使用复合唯一索引,那么仅仅当设置的值全部都重复出现,是一模一样的,才会出错误,其他情况下,只有一个索引列不一样也是正确的;


               2.同时,对于复合索引设置的时候,也要注意设置的先后顺序,对于查询也是有一定影响的


  select * from emp1 where name = '张三';
  
  select * from emp1 where id = 1001;
  
  select * from emp1 where id=1001 and name='张三';
  
  select * from emp1 where name ='张三' and id =1001;
 
*前提,设置的复合唯一索引(id,name)
 
对于1进行查询的时候,不会使用复合唯一索引查询,因为没有提供设置的第一个唯一索引---id
而对于2,3都能够使用设置的复合唯一索引进行快速查询
 
即便是对于4,因为MYSQL系统会自动对其进行一定的优化,因此我们可以理解为3,4两个方式在mysql当中的作用是一样的

3.全文索引

 1.介绍

   1.关键词:fulltext

  2.跟之前所学习的关键字like很像,全文索引主要是用来寻找文本当中的关键字,而不是直接跟索引当中的值进行比较,更像是一个搜索引擎,是以相似度为基本的查询,而不是简单的where语句的参数匹配查询

     3.但是跟like查询不一样的是,like的查询适用于对于数据量比较小的,而全文索引更加适用于大量级别的文本查询,查询速度相比于like的文本查询快了几个数量级!但是全文索引的查询可能会存在一些的精度问题

 2.操作:

创建全文索引的方法
  一:alter table tablename add fulltext fulltextname(var1,var2....);
  示例:对于表test添加的content添加全文索引
  alter table test add fulltext full_content(content);
  
  二:
  create fulltext index indexname on tablename(var1...);
 
使用全文索引
  关键字:match(var1) against(查询内容);
  
  示例:
  查询表test当中所有包含yo的内容,使用全文查询
  select * from test match(content) against('yo');  -- 查询不到,因为查询的最小搜索长度是3
  select * from test match(content) against('you'); -- 可以查询到,满足最小的查询长度

  3.TIPS:

               如果想要通过全文索引查询,必须要注意的是全文索引的两个量(最小搜索长度以及最大搜索长度) 大于,或者是小于这个范围的搜索内容都无法搜索到!

       

    可以使用
    show variables like '%ft%';  查看相应的数值大小

 4:空间索引:

       1.介绍:

  1>MYSQL仅仅在5.7之后才支持空间索引

       2>空间索引针对的是空间数据类型的字段建立的索引,MYSQL中的空间数据类型主要有4种,geometry,point,linestring,polygon

       3>并且在创建空间索引的时候,这个索引列必须是not null 类型的  

2.操作:

geometry  含义:空间数据  说明:任何一种空间类型
  point  含义:点  说明:坐标值
  lineString  含义:线  说明:有一系列点连接而成的
  polygon  含义:多边形  说明:由多条线组成
  
  操作:
  create table spa_0(
  id int primary key auto_increment,  -- 'id'
  name VARCHAR(20), -- 门店名称
  point_1 geometry not null,    -- 经纬度表示 
spatial key sap_index(point_1)
  );
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
18天前
|
存储 自然语言处理 关系型数据库
MySQL高级篇——索引的创建与设计原则
索引的分类与使用、MySQL8.0索引新特性、适合创建索引的情况、不适合创建索引的情况
MySQL高级篇——索引的创建与设计原则
|
18天前
|
存储 SQL 关系型数据库
MySQL高级篇——索引失效的11种情况
索引优化思路、要尽量满足全值匹配、最佳左前缀法则、主键插入顺序尽量自增、计算、函数导致索引失效、类型转换(手动或自动)导致索引失效、范围条件右边的列索引失效、不等于符号导致索引失效、is not null、not like无法使用索引、左模糊查询导致索引失效、“OR”前后存在非索引列,导致索引失效、不同字符集导致索引失败,建议utf8mb4
MySQL高级篇——索引失效的11种情况
|
27天前
|
存储 关系型数据库 MySQL
MySQL基础:索引
MySQL中的索引是一种数据结构,能大幅提升数据库查询效率和减少I/O成本,类似于书的目录帮助快速定位内容。其优势包括提高检索效率和降低排序成本,但会占用空间并影响更新表的效率。鉴于查询远多于更新,索引仍被推荐使用。索引分为多种类型,如B+树和哈希索引,其中B+树因其较低的高度和稳定的查询开销成为常用选择。创建和删除索引需谨慎,以免影响性能。
42 4
MySQL基础:索引
|
18天前
|
存储 SQL 关系型数据库
【MySQL调优】如何进行MySQL调优?从参数、数据建模、索引、SQL语句等方向,三万字详细解读MySQL的性能优化方案(2024版)
MySQL调优主要分为三个步骤:监控报警、排查慢SQL、MySQL调优。 排查慢SQL:开启慢查询日志 、找出最慢的几条SQL、分析查询计划 。 MySQL调优: 基础优化:缓存优化、硬件优化、参数优化、定期清理垃圾、使用合适的存储引擎、读写分离、分库分表; 表设计优化:数据类型优化、冷热数据分表等。 索引优化:考虑索引失效的11个场景、遵循索引设计原则、连接查询优化、排序优化、深分页查询优化、覆盖索引、索引下推、用普通索引等。 SQL优化。
164 15
【MySQL调优】如何进行MySQL调优?从参数、数据建模、索引、SQL语句等方向,三万字详细解读MySQL的性能优化方案(2024版)
|
18天前
|
存储 缓存 关系型数据库
MySQL高级篇——存储引擎和索引
MyISAM:不支持外键和事务,表锁不适合高并发,只缓存索引,内存要求低,查询快MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM不支持事务、行级锁、外键,有一个毫无疑问的缺陷就是崩溃后无法安全恢复。5.5之前默认的存储引擎优势是访问的速度快,对事务完整性没有要求或者以SELECT、INSERT为主的应用针对数据统计有额外的常数存储。故而 count(*) 的查询效率很高表名.frm 存储表结构;表名.MYD 存储数据 (MYData);
MySQL高级篇——存储引擎和索引
|
18天前
|
存储 关系型数据库 MySQL
MySQL高级篇——覆盖索引、前缀索引、索引下推、SQL优化、主键设计
覆盖索引、前缀索引、索引下推、SQL优化、EXISTS 和 IN 的区分、建议COUNT(*)或COUNT(1)、建议SELECT(字段)而不是SELECT(*)、LIMIT 1 对优化的影响、多使用COMMIT、主键设计、自增主键的缺点、淘宝订单号的主键设计、MySQL 8.0改造UUID为有序
MySQL高级篇——覆盖索引、前缀索引、索引下推、SQL优化、主键设计
|
2天前
|
存储 关系型数据库 MySQL
MySQL索引失效及避免策略:优化查询性能的关键
MySQL索引失效及避免策略:优化查询性能的关键
13 3
|
7天前
|
关系型数据库 MySQL 数据库
MySQL删除全局唯一索引unique
这篇文章介绍了如何在MySQL数据库中删除全局唯一的索引(unique index),包括查看索引、删除索引的方法和确认删除后的状态。
28 9
|
2天前
|
存储 SQL 关系型数据库
MySQL 的索引是怎么组织的?
MySQL 的索引是怎么组织的?
8 1
|
2天前
|
存储 关系型数据库 MySQL
MySQL索引的概念与好处
本文介绍了MySQL存储引擎及其索引类型,重点对比了MyISAM与InnoDB引擎的不同之处。文中详细解释了InnoDB引擎的自适应Hash索引及聚簇索引的特点,并阐述了索引的重要性及使用原因,包括提升数据检索速度、实现数据唯一性等。最后,文章还讨论了主键索引的选择与页分裂问题,并提供了使用自增字段作为主键的建议。
MySQL索引的概念与好处