(1)索引面试题分析
data:image/s3,"s3://crabby-images/6e296/6e2963df4719e6f686b05131ed90bf1ae6c4cadb" alt=""
data:image/s3,"s3://crabby-images/ac5b8/ac5b8aba640adf45c796f04414539097739e03ff" alt=""
data:image/s3,"s3://crabby-images/d1ed0/d1ed0bf8f566efc008905e2948fbb1ca9bc4443a" alt=""
所谓索引:就是排好序的快速查找数据结构,排序家查找是索引的两个用途
data:image/s3,"s3://crabby-images/30cfb/30cfbc68193c6ddc5f8cdc34c448799afeaa2f09" alt=""
data:image/s3,"s3://crabby-images/2110e/2110ed2304fbf3a76a35be07d98fcdd005bd09c6" alt=""
select * 在where使用到了索引,当select * 有模糊查询%在左边索引会失效
data:image/s3,"s3://crabby-images/055c8/055c8b00f408a54a84710c682ac0afc9f8b81ad3" alt=""
data:image/s3,"s3://crabby-images/a628d/a628d8e273d480e66dc01ce9ee981f1020f21d10" alt=""
当select * where后面索引的顺序发生变化,也会用到索引4个
我们where后面倒着排序,也会使用到索引4个
data:image/s3,"s3://crabby-images/aae29/aae298f6712c65e5fd882d8c505648bfb9a6939d" alt=""
上面,因为有MySql查询优化器,它会把Msql的命令自动的调整和优化,已达到最佳效果
查询* ,where后面c3>a3,用到了范围导致索引失效 ,用到了3个索引c1 c2 c3,大小93
data:image/s3,"s3://crabby-images/7eaf7/7eaf77113055c0949bbc73596f54a95152e83255" alt=""
用到了范围导致索引失效 ,Msql优化器话进行优化,用到了4个索引c1 c2 c3c4 ,大小124
data:image/s3,"s3://crabby-images/12719/127190153df8a15753fd936eb9cfa7baebdc7cb8" alt=""
用到2个索引,大小62,严格来说c3也用到了,它没有用于查找,用于了排序
data:image/s3,"s3://crabby-images/7ba0d/7ba0d2779cfa4c542917a353caed23d9fa9166b4" alt=""
data:image/s3,"s3://crabby-images/e81cc/e81cc543922e5b3257d2ad0c107274fddc639400" alt=""
Extra:出现了Using filesort,因为where后面没有按照我建立索引的顺序使用缺少了c3,用c4去排序,产生了文件内排序,这个是非常影响性能的
data:image/s3,"s3://crabby-images/cdfd1/cdfd1acc1fc727150f78b4d008fdb3527d4473d9" alt=""
用到1个索引:c1,c2c3用到去排序去啦
出现了文件内排序,因为order by 后面没有按照建立索引的顺序使用
data:image/s3,"s3://crabby-images/e8133/e81339f7e968e00e5f0624af60532b7478886de3" alt=""
用到2个索引c1c2 查找和排序都是按照顺序的
data:image/s3,"s3://crabby-images/cb12b/cb12bec26b312476899c0412f158223f0e7f1a28" alt=""
用到2个索引c1c2 查找和排序都是按照顺序的
只要order by 使用的跟建立的顺序不一样们就会产生文件内排序,这个是个例外,因为排序字段已经是一个常量了,常量了排序就没用了,就没有产生文件内排序,跟下面那个进行对比
data:image/s3,"s3://crabby-images/a6424/a6424f9fcc060f40dbd4e255a4a092eb106d4ead" alt=""
用到了group by后按照顺序,这里索引用到了一个c1
data:image/s3,"s3://crabby-images/3f9e2/3f9e27ed536c0b6db84c8f4a00c669049f40d2ad" alt=""
用到了group by,这里索引用到了一个c1,但是group by没有按照索引的顺序,多了Using filesort 和Using temporary
data:image/s3,"s3://crabby-images/55889/55889eb8a308feed44acfd47210bed730c5aeef0" alt=""
data:image/s3,"s3://crabby-images/3352c/3352cee8b90ca21288a83eb22f6b956601328fb7" alt=""
(2)总结口诀
当中间使用like %(在右边)也是范围查询是具体的范围查询,type为range它跟>不一样,他能使用到like后的索引,用到了3个索引
data:image/s3,"s3://crabby-images/8461c/8461ca8f5f8368f62df51d13edec6759599d8c7b" alt=""
当中间使用like %(在左边)不是具体的范围,这个type不是range,只用到一个索引c1
当中间使用like % ... %(两个%)不是具体的范围,这个type不是range,只用到一个索引c1
当中间使用like %(最左边有具体的开头)使用到3个索引
data:image/s3,"s3://crabby-images/c5f09/c5f095c858d0ea47cde7108802d8190c53222d90" alt=""
data:image/s3,"s3://crabby-images/fce09/fce09c4009e57a2818b3ca78575eb711dbc9f7f1" alt=""