從sql語句自建數據表開始測試:
-- 創建表 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;  -- 添加記錄 INSERT INTO test VALUES((1,'jay'),(2,'ja'),(3,'bril'),(4,'aybar');
檢測結果:
filtered:它指返回結果的行占需要讀到的行(rows列的值)的百分比。
EXPLAIN SELECT * FROM test WHERE uname LIKE 'j';
EXPLAIN SELECT * FROM test WHERE uname LIKE 'j%';
EXPLAIN SELECT * FROM test WHERE uname LIKE '%j';
EXPLAIN SELECT * FROM test WHERE uname LIKE '%j%';
這么看來 %的使用對索引似乎沒有印象,但是再加一個普通不是索引的字段
--添加一個非索引字段 ALTER TABLE `test` ADD COLUMN `status` int(11) UNSIGNED NULL DEFAULT 1 AFTER `uname`
再次檢測:
EXPLAIN SELECT * FROM test WHERE uname LIKE 'j';
EXPLAIN SELECT * FROM test WHERE uname LIKE 'j%';
EXPLAIN SELECT * FROM test WHERE uname LIKE '%j';
EXPLAIN SELECT * FROM test WHERE uname LIKE '%j%';
這次的結果是: like后直接跟%號的匹配的查詢不使用索引;like后先跟匹配值%,就會使用到索引。
----疑問???
|那么為啥加了一個字段后會有這樣的區別呢?之前的字段是id,uname id是主鍵,也是索引的一部分 所以select * 取的兩個字段都是索引字段。所以 like 語句都會使用到索引。
后面加了一個非索引字段status,並且取數據列表里也存在status字段,所以%在匹配值前的情況就會受影響。
當然如果不是select * ,而是select id 或者select uname 再或者 select id,uname 都會使用上索引。
具體的還希望自己動手試一下哈。聽到的不如看到的;看到的不如自己親手實踐出來的。