当前位置: 首页 > news >正文

黑马程序员索引学习笔记

文章目录

    • 索引的分类
      • 从索引字段特性
      • 从物理存储
      • 从数据结构
      • 组成索引的字段个数
    • InnoDB主键索的B+tree高度为多高呢?
    • explain执行计划
    • 最左匹配原则
    • 索引失效情况
    • SQL提示
    • 覆盖索引、回表查询
    • 前缀索引
    • 索引设计原则

索引的分类

从索引字段特性

主键索引、唯一索引、常规索引、全文索引
在这里插入图片描述

从物理存储

聚簇(集)索引、二级索引
在这里插入图片描述

从数据结构

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

InnoDBMyISAMMemory
B+ tree索引YesYesYes
Hash索引NoNoYes
Full-text索引YesYesNo

组成索引的字段个数

单列索引、联合索引

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

在这里插入图片描述
图片中n表示主键个数,n+1表示指针数量。

explain执行计划

在这里插入图片描述

最左匹配原则

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

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

索引失效情况

  • 在索引字段上进行运算
explain select * from tb_user where substring(phone, 10, 2) = '15';
  • 字符串类型字段使用时,不加引号
-- 此处phone的值没有加引号
desc select * from tb_user where phone = 17799990015;
  • 头部模糊查询(即%在前面)匹配
-- 此处%在前面
explain select * from tb_user where profession like '%工程';
  • 用or分割开的条件,其中某一列没有索引,那么涉及的索引都不会被用到。
-- 必须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建立联合索引,避免回表查询。

前缀索引

在这里插入图片描述

索引设计原则

在这里插入图片描述

http://www.lryc.cn/news/246358.html

相关文章:

  • 新手如何对一个web网页进行一次渗透测试
  • vs2019 - MFC对话框程序的工程名称不支持下划线命名法
  • java JDBCUtils 使用静态代码块连接数据库 全程值保持一次连接
  • 剑指 Offer(第2版)题解(C++ Version)
  • 6.15合并二叉树(LC617-E)
  • 百度智能小程序系统源码+关键词排名优化 附带完整的搭建教程
  • 2019年11月7日 Go生态洞察:Go Modules v2及更高版本
  • vue3通过provide和inject实现多层级组件通信
  • 【Java学习笔记】72 - 满汉楼 - 餐饮管理系统
  • 【我的创作纪念日】
  • 车载通信架构 —— 传统车内通信网络MOST总线(光纤传输、专精多媒体)
  • 使用Pytorch从零开始构建Energy-based Model
  • 基于C#实现梳排序
  • 盘点72个Android系统源码安卓爱好者不容错过
  • nodejs+vue+elementui足球篮球联赛系统
  • 18.Oracle的过程和函数
  • A JSONObject text must begin with ‘{‘ at 1 [character 2 line 1]
  • C#中openFileDialog控件的使用方法
  • 多线程04 死锁,线程可见性
  • java中文转拼音(去除音调)
  • [Android]常见的数据传递方式
  • <蓝桥杯软件赛>零基础备赛20周--第7周--栈和二叉树
  • 探究Kafka原理-7.exactly once semantics 和 性能测试
  • 【密码学引论】序列密码
  • 知识变现的未来:解析知识付费系统的核心
  • 【Linux基础】Linux常见指令总结及周边小知识
  • 【Android知识笔记】性能优化专题(五)
  • Java基础之泛型
  • WPF实战项目十五(客户端):RestSharp的使用
  • C语言基础篇5:指针(二)