黑马程序员索引学习笔记

文章目录

索引的分类

从索引字段特性

主键索引、唯一索引、常规索引、全文索引

从物理存储

聚簇(集)索引、二级索引

从数据结构

B+树索引、Hash索引、全文索引

InnoDB MyISAM Memory
B+ tree索引 Yes Yes Yes
Hash索引 No No Yes
Full-text索引 Yes Yes No

组成索引的字段个数

单列索引、联合索引

InnoDB主键索的B+tree高度为多高呢?


图片中n表示主键个数,n+1表示指针数量。

explain执行计划

最左匹配原则

  • 如果索引了多列(联合索引),要遵守最左前缀法则。
  • 最左前缀法则指的是查询从索引的最左列开始,并且不跳过索引中的列。
  • 如果跳跃某一列,索引将部分失效(后面的字段索引失效)。
  • 范围查询(不含等于)后面的字段不走索引。

注:查询字段存在即可和sql顺序无关

索引失效情况

  • 在索引字段上进行运算
sql 复制代码
explain select * from tb_user where substring(phone, 10, 2) = '15';
  • 字符串类型字段使用时,不加引号
sql 复制代码
-- 此处phone的值没有加引号
desc select * from tb_user where phone = 17799990015;
  • 头部模糊查询(即%在前面)匹配
sql 复制代码
-- 此处%在前面
explain select * from tb_user where profession like '%工程';
  • 用or分割开的条件,其中某一列没有索引,那么涉及的索引都不会被用到。
sql 复制代码
-- 必须id和name都有索引,才可以用到索引
desc select * from t_achievement_application where id = 66 or name = '张三';
  • 如果MySQL评估使用索引比全表更慢,则不使用索引。(参考范围查询、is null、is not null)
    is null、is not null是否走索引取决于表中的数据分布。

SQL提示

其中 use是建议MySQL用这个索引

覆盖索引、回表查询

尽量使用覆盖索引(查询使用了索引,并且需要返回的列,在该索引中已经全部能够找到),减少select *。

Extra列描述

NULL: 需要回表查询

using index condition : 查找使用了索引,但是需要回表查询数据

using where; using index : 查找使用了索引,但是需要的数据都在索引列中能找到,所以不需要回表查询数据

username、password建立联合索引,避免回表查询。

前缀索引

索引设计原则

相关推荐
炽烈小老头6 小时前
【 每天学习一点算法 2026/04/12】x 的平方根
学习·算法
阿杰学AI6 小时前
AI核心知识115—大语言模型之 自监督学习(简洁且通俗易懂版)
人工智能·学习·ai·语言模型·aigc·监督学习·自监督学习
九英里路7 小时前
OS学习之路——动静态库制作与原理
linux·学习·操作系统·unix·进程·编译·动静态库
red_redemption7 小时前
自由学习记录(160)
学习
南無忘码至尊7 小时前
Unity学习90天-第2天-认识Unity生命周期函数并用 Update 控制物体移动,FixedUpdate 控制物理
学习·unity·游戏引擎
报错小能手8 小时前
ios开发方向——swift错误处理:do/try/catch、Result、throws
开发语言·学习·ios·swift
Z.风止8 小时前
Large Model-learning(3)
人工智能·笔记·后端·深度学习
LX567778 小时前
传统销售如何系统学习成为AI智能销售顾问?认证指南
人工智能·学习
做cv的小昊8 小时前
【TJU】应用统计学——第五周作业(3.1 假设检验的基本思想、3.2 单个正态总体参数的假设检验)
学习·线性代数·机器学习·数学建模·矩阵·概率论·tju
格鸰爱童话9 小时前
向AI学习项目技能(六)
java·人工智能·spring boot·python·学习