点击上方 好好学java ,选择 星标 公众号重磅资讯,干货,第一时间送达
今日推荐:14 个 github 项目!个人原创100W +访问量博客:点击前往,查看更多

  作者:绕远的偶人

blog.csdn.net/weixin_39420024/article/details/80040549

1、分类

MySQL索引分为普通索引、唯一索引、主键索引、组合索引、全文索引。索引不会包含有null值的列,索引项可以为null(唯一索引、组合索引等),但是只要列中有null值就不会被包含在索引中。

(1)普通索引: create index index_name on table(column);

或者创建表时指定,create table(..., index index_name column);

(2)唯一索引: 类似普通索引,索引列的值必须唯一(可以为空,这点和主键索引不同)

create unique index index_name on table(column);或者创建表时指定unique index_name column

(3)主键索引: 特殊的唯一索引,不允许为空,只能有一个,一般是在建表时指定primary key(column)

(4)组合索引: 在多个字段上创建索引,遵循最左前缀原则。alter table t add index index_name(a,b,c);

(5)全文索引: 主要用来查找文本中的关键字,不是直接与索引中的值相比较,像是一个搜索引擎,配合match against使用,现在只有char,varchar,text上可以创建全文索引。

在数据量较大时,先将数据放在一张没有全文索引的表里,然后再利用create index创建全文索引,比先生成全文索引再插入数据快很多。

2、何时使用索引

MySQL每次查询只使用一个索引。与其说是“数据库查询只能用到一个索引”,倒不如说,和全表扫描比起来,去分析两个索引B+树更加耗费时间。所以where A=a and B=b这种查询使用(A,B)的组合索引最佳,B+树根据(A,B)来排序。

  1. 主键,unique字段;

  2. 和其他表做连接的字段需要加索引;

  3. 在where里使用>,≥,=,<,≤,is null和between等字段;

  4. 使用不以通配符开始的like,where A like 'China%';

  5. 聚集函数MIN(),MAX()中的字段;

  6. order by和group by字段;

3、何时不使用索引

  1. 表记录太少;

  2. 数据重复且分布平均的字段(只有很少数据值的列);

  3. 经常插入、删除、修改的表要减少索引;

  4. text,image等类型不应该建立索引,这些列的数据量大(假如text前10个字符唯一,也可以对text前10个字符建立索引);

  5. MySQL能估计出全表扫描比使用索引更快时,不使用索引;

4、索引何时失效

  1. 组合索引未使用最左前缀,例如组合索引(A,B),where B=b不会使用索引;

  2. like未使用最左前缀,where A like '%China';

  3. 搜索一个索引而在另一个索引上做order by,where A=a order by B,只使用A上的索引,因为查询只使用一个索引 ;

  4. or会使索引失效。如果查询字段相同,也可以使用索引。例如where A=a1 or A=a2(生效),where A=a or B=b(失效)

  5. 如果列类型是字符串,要使用引号。例如where A='China',否则索引失效(会进行类型转换);

  6. 在索引列上的操作,函数(upper()等)、or、!=(<>)、not in等;

5、explain语句

type字段为All,未使用索引;为ref,使用索引

  • ALL: 全表扫描

  • index: 索引全扫描

  • range: 索引范围扫描,常用语<,<=,>=,between等操作

  • ref: 使用非唯一索引扫描或唯一索引前缀扫描,返回单条记录,常出现在关联查询中

  • eq_ref: 类似ref,区别在于使用的是唯一索引,使用主键的关联查询

  • const/system: 单条记录,系统会把匹配行中的其他列作为常数处理,如主键或唯一索引查询

  • null: MySQL不访问任何表或索引,直接返回结果

还有key字段表示用到的索引,没有用到为null

推荐文章
  • 开发者工具 Top 100 名单

  • 2020年国内互联网公司的薪酬排名!

  • 不要再封装各种Util工具类了,这个神级框架值得拥有!

  • 写博客能月入10K?

  • 一款基于 Spring Boot 的现代化社区(论坛/问答/社交网络/博客)

更多项目源码
  • 这或许是最美的Vue+Element开源后台管理UI

  • 推荐一款高颜值的 Spring Boot 快速开发框架

  • 一款基于 Spring Boot 的现代化社区(论坛/问答/社交网络/博客)

  • 13K点赞都基于 Vue+Spring 前后端分离管理系统ELAdmin,大爱

  • 想接私活时薪再翻一倍,建议根据这几个开源的SpringBoot项目

MySQL索引的分类、何时使用、何时不使用、何时失效?相关推荐

  1. MySQL索引的分类

    索引的分类 MySQL的索引包括普通索引.唯一性索引.全文索引.单列索引.多列索引和空间索引等. 从 功能逻辑 上说,索引主要有 4 种,分别是 普通索引.唯一索引.主键索引.全文索引 按照 物理实现 ...

  2. 一文搞懂 MySQL 索引

    一文搞懂 MySQL 索引 1.MySQL 索引 简介 1.1.MySQL 索引 是什么?  索引是一个单独的.存储在 磁盘 上的 数据库结构 ,包含着对数据表里 所有记录的 引用指针. 1.2. M ...

  3. mysql 索引优缺点

    1:联合索引 适用于最左匹配原则 例如 设置一个联合索引 三个字段 从最左边开始匹配,如果遇到没有使用索引,则这个索引后的设置的索引也将会失效. 遇到范围匹配时,索引也会失效. 2:不使用索引情况:当 ...

  4. Mysql 索引 总结 —— 概述 || 索引优势劣势|| 索引结构(索引是在MySQL的存储引擎层中实现的)|| BTREE 结构||B+TREE 结构||MySQL中的B+Tree||索引分类

    索引概述 MySQL官方对索引的定义为:索引(index)是帮助MySQL高效获取数据的数据结构(有序). 在数据之外,数据库系统还维护者满足特定查找算法的数据结构, 这些数据结构以某种方式引用(指向 ...

  5. MySQL中索引的分类和基本操作

    索引的作用:是用于快速定位实际数据位置的一种机制. 索引在mysql中,是独立于数据的一种特殊的数据结构. 一.索引的分类 普通索引:利用特定的关键字,标识数据记录的位置(磁盘上的位置,盘号,柱面,扇 ...

  6. Mysql索引分类及其使用实例

    Mysql索引 Mysql的索引分类 单列索引 创建单列索引的几种方式: 唯一索引 创建唯一索引的几种方式: 联合索引(复合索引) 创建联合索引(复合索引)的方式: Mysql的索引类型 INDEX ...

  7. MySQL索引有哪些分类,你真的清楚吗?

    MySQL官方对索引的定义是:索引(Index)是帮助MySQL高效获取数据的数据结构.索引最形象的比喻就是图书的目录.注意只有在大量数据中查询时索引才显得有意义. 在MySQL中索引是在存储引擎层实 ...

  8. mysql 索引index_MySQL查询优化之 index 索引的分类和使用

    索引的分类 主键索引 (PRIMARY KEY) 唯一的标识符, 主键不可重复, 只能有一列作为主键 唯一索引 (Unique KEY) 避免重复的列出现, 唯一索引可以重复, 多个列都可以标识为唯一 ...

  9. Mysql索引优缺点以及分类

    索引是对数据库表中一列或多列的值进行排序的一种结构.MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度.索引只是提高效率的一个因素,如果你的MySQL有大数据 ...

最新文章

  1. Git 常用命令清单,掌握这些,轻松驾驭版本管理
  2. 最长回文子序列(算法导论15-2
  3. HDU 1009 - FatMouse' Trade (部分背包问题)
  4. a标签,选中当前菜单后高亮
  5. SOA与EAI的比较
  6. java数据结构有哪些_java有哪些数据结构?
  7. [ECMAScript] 说说你对class的理解
  8. 太厉害了!3小时34分!53岁院士施一公完成人生首马
  9. 2019年最流行的七大编程语言:学习编程,你会选择哪一种语言呢?
  10. 滴滴老板:程维的故事
  11. 究竟 javascript 错误处理有哪些类型?
  12. 不会装系统?有这篇就够了!
  13. 最常用的网络应用工具之寻线仪
  14. coco 数据集_PyTorch版YOLOv4更新了,适用于自定义数据集
  15. java.lang.IllegalArgumentException: addChild: Child name '/SSHE' is not unique
  16. 浅谈Delphi过程与函数03 - 零基础入门学习Delphi22
  17. kmeans算法c语言代码,ML算法与代码实现——Kmeans(案例)
  18. 4000汉字无一重字
  19. 这几个用 Pyecharts 做出来的交互图表,领导说叼爆了!
  20. QQ快捷登录提示:禁止开发商强制用户重新注册或绑定其他帐号

热门文章

  1. C语言写的流氓关机程序及破解
  2. 哪些情况下索引会失效?
  3. 使用socket的Linux上的C语言文件传输顺序服务器和客户
  4. Java教程 实战学习Struts实例
  5. C语言中函数可变参数解析
  6. AB1601蓝牙初始化注意事项
  7. kmalloc/kfree,vmalloc/vfree函数用法和区别
  8. 第七章-NoSQL数据库
  9. 差分能量分析介绍(二)
  10. 近世代数--整环上的唯一分解问题--相伴是整环上的等价关系,最大公因子建立在相伴所划分的等价类上