今天看了一篇对于like使用对索引的影响的文章,发现自己实践的跟文章得出结论不大一样。所以还是建议自己再看别人文章的时候自己亲自动手实践一下。以免学到不全面的知识。

列子:

先建立一张表:

-- 创建表
CREATE TABLE test(
id INT(11) NOT NULL AUTO_INCREMENT,
uname VARCHAR(255),
PRIMARY KEY(id)
);

再在uname字段上创建索引:

-- 添加索引
ALTER TABLE test ADD INDEX uname_index (uname); -- 查看索引
SHOW INDEX FROM test;
![](https://img2018.cnblogs.com/blog/905539/201810/905539-20181010143352460-197551940.png) -- 添加记录
INSERT INTO test VALUES((1,'jay'),(2,'ja'),(3,'bril'),(4,'aybar');

检测结果:

EXPLAIN SELECT * FROM test WHERE uname LIKE 'j';

MySQL 中like的使用对于索引的影响-LMLPHP

EXPLAIN SELECT * FROM test WHERE uname LIKE 'j%';

MySQL 中like的使用对于索引的影响-LMLPHP

EXPLAIN SELECT * FROM test WHERE uname LIKE '%j';

MySQL 中like的使用对于索引的影响-LMLPHP

EXPLAIN SELECT * FROM test WHERE uname LIKE '%j%';

MySQL 中like的使用对于索引的影响-LMLPHP

这么看来 %的使用对索引似乎没有印象,但是再加一个普通不是索引的字段

--添加一个非索引字段
ALTER TABLE `test`
ADD COLUMN `status` int(11) UNSIGNED NULL DEFAULT 1 AFTER `uname`

再次检测:

EXPLAIN SELECT * FROM test WHERE uname LIKE 'j';

MySQL 中like的使用对于索引的影响-LMLPHP

EXPLAIN SELECT * FROM test WHERE uname LIKE 'j%';

MySQL 中like的使用对于索引的影响-LMLPHP

EXPLAIN SELECT * FROM test WHERE uname LIKE '%j';

MySQL 中like的使用对于索引的影响-LMLPHP

EXPLAIN SELECT * FROM test WHERE uname LIKE '%j%';

MySQL 中like的使用对于索引的影响-LMLPHP

这次的结果是: like后直接跟%号的匹配的查询不使用索引;like后先跟匹配值%,就会使用到索引。

----疑问???

|那么为啥加了一个字段后会有这样的区别呢?之前的字段是id,uname id是主键,也是索引的一部分 所以select * 取的两个字段都是索引字段。所以 like 语句都会使用到索引。

后面加了一个非索引字段status,并且取数据列表里也存在status字段,所以%在匹配值前的情况就会受影响。

当然如果不是select * ,而是select id 或者select uname 再或者 select id,uname 都会使用上索引。

具体的还希望自己动手试一下哈。听到的不如看到的;看到的不如自己亲手实践出来的。

本人也在学习阶段,若有不正确不恰当的地方还希望能多多指教!

05-27 18:48