mysql的like是否使用索引

mysql的like是否使用索引

mysql在使用like查询中,能不能用到索引?在什么地方使用索引呢?在使用like的时候,如果使用‘%%’,会不会用到索引呢?

EXPLAIN SELECT * FROM `user` WHERE username LIKE '%ptd_%';

MYSQL查询索引使用之like - hawk_wolf - hawk_wolf

 上面的结果是全表扫描,并没有使用到索引。

只是使用一个%的查询结果:

EXPLAIN SELECT * FROM `user` WHERE username LIKE 'ptd_%';

MYSQL查询索引使用之like - hawk_wolf - hawk_wolf

这个使用到了索引。

EXPLAIN SELECT * FROM `user` WHERE username LIKE '%ptd_';

MYSQL查询索引使用之like - hawk_wolf - hawk_wolf

在前面使用%时也是全表扫描,没有使用到索引。

综上,mysql在使用like查询的时候只有使用后面的%时,才会使用到索引。

猜你喜欢

转载自blog.csdn.net/weberhuangxingbo/article/details/83538952