Mysql like ' ' 会不会用到索引(转)
mysql在使用like查询中,能不能用到索引?在什么地方使用索引呢?
在使用like的时候,如果使用‘%%’,会不会用到索引呢?
EXPLAIN SELECT * FROM `user` WHERE username LIKE '%ptd_%';
![MYSQL查询索引使用之like - hawk_wolf - hawk_wolf](http://img1.ph.126.net/1WJjSZfbV0ddOanJAhnJQg==/2809120267590393403.png)
只是使用一个%的查询结果:
EXPLAIN SELECT * FROM `user` WHERE username LIKE 'ptd_%';
![MYSQL查询索引使用之like - hawk_wolf - hawk_wolf](http://img0.ph.126.net/zMhJ-aC2h3vtuKiu0wTDEg==/6631243687559807394.png)
这个使用到了索引(type == range)。
EXPLAIN SELECT * FROM `user` WHERE username LIKE '%ptd_';
![MYSQL查询索引使用之like - hawk_wolf - hawk_wolf](http://img2.ph.126.net/3jBh_PBR-4MorRp_hmEMJg==/63613344754718057.png)
在前面使用%时也是全表扫描,没有使用到索引。
综上,mysql在使用like查询的时候只有不以%开头的时候,才会使用到索引。