zoukankan      html  css  js  c++  java
  • MySQL 中like的使用对于索引的影响

    从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;
    ![](https://img2018.cnblogs.com/blog/905539/201810/905539-20181010143352460-197551940.png)
    
    -- 添加记录
    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 都会使用上索引。

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

  • 相关阅读:
    iis 5.0 不能运行 asp.net 的 原因
    股票在线讨论
    adsl 加 路由器 网关不能上网的 原因
    汽车英语
    势与子的辩证法
    中国上海的黑心培训学校
    excel 里的 图表的使用
    带宽 下载速度 比特 率 换算 速度
    硬盘分区表修复秘籍
    Bootstrap a标签的单击时停止传播事件
  • 原文地址:https://www.cnblogs.com/shengguorui/p/11318933.html
Copyright © 2011-2022 走看看