(4)type:重点
从最好到最差依次是: system>const>eq_ref>ref>range>index>all
data:image/s3,"s3://crabby-images/d4ca3/d4ca35d8f7930df488a9a14994c3679b6fc799d0" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/4ae36/4ae36c489a9b5cdee8f3565d281cf4ecb73e9bbf" alt="在这里插入图片描述" eq_ref:双表:前一个表的唯一索引只能在后表中找到唯一记录
(5)key、possible_keys(可以用来做索引失效的校验)
查询的字段就在索引中(顺序和个数都匹配),此时展示的情况就是possible_keys为空但key中有值 (6)key_len: data:image/s3,"s3://crabby-images/0a746/0a7468311bdc11af9bb5b6e05c8742df215c9ada" alt="在这里插入图片描述" key_len只计算where条件用到的索引长度,单列索引计算整个索引长度,多列索引用多少算多少 (7)ref
格式:库.表.字段 const data:image/s3,"s3://crabby-images/63720/6372061638f5f8d5e1eb7f61700a8bdc857e40ef" alt="在这里插入图片描述" (8)rows
data:image/s3,"s3://crabby-images/e46d8/e46d863abbc7d3e1c651b6bd0cb31dbe5ff66412" alt="在这里插入图片描述" (9)extra 额外内容 data:image/s3,"s3://crabby-images/3301f/3301fb81e6301419bf6a9f76b5373f5c4ee5a1b2" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/84779/84779c1257f021b667cccab3f75f696ccb58f34f" alt="在这里插入图片描述" Using filesort说明:最左原则,中间如果断了就不走索引了
前3个是extra中最重要的指标 data:image/s3,"s3://crabby-images/8ddce/8ddce4c7333948922a1903b36668a41bec872741" alt="在这里插入图片描述"
三、索引优化
单表分析
范围之后的索引会失效 data:image/s3,"s3://crabby-images/6ac11/6ac1139857b748fdd4d95b2266d2d4cd1f62fdd4" alt="在这里插入图片描述" 结论:跳过范围比较的字段来创建索引
data:image/s3,"s3://crabby-images/da28b/da28b0f1ea1d34b5b3c05db291f66705ecd0b29a" alt="在这里插入图片描述"
两表分析
问题:加在左表还是右表,主键还是外键 分析: 第一种情况:左连接把索引加在了右表上 data:image/s3,"s3://crabby-images/41c1c/41c1c73d6715268b77fae340b54b9e91b4b7d1ae" alt="在这里插入图片描述" 第二种情况:左连接把索引加在了左表上
data:image/s3,"s3://crabby-images/73977/73977aeb0cf473361c962350d24e6a2027f067ee" alt="在这里插入图片描述"
结论:左右连接索引相反加(加在从表上效率高)
(对应:可以尝试更换sql语句中的主从表位置)
三表分析
data:image/s3,"s3://crabby-images/47346/4734689a9627df7274bb5789aa2cd49699de839a" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/3c415/3c41523248020536be979137cac63322058ed86f" alt="在这里插入图片描述" 结论:索引最好设置在需要经常查询的字段上
data:image/s3,"s3://crabby-images/ae27a/ae27a4475255a74340332577a98e28c8f5b06237" alt="在这里插入图片描述"
|