zoukankan      html  css  js  c++  java
  • mysql 索引

    innodb引擎:

     索引(Index)是帮助MySQL高效获取数据的数据结构。我们可以简单理解为:快速查找排好序的一种数据结构

    explain:

    possible_key:可能用到的索引
    key:用到的索引

    无索引:

    #无索引
    EXPLAIN SELECT * FROM a WHERE id like "%3";
    #无索引
    EXPLAIN SELECT * FROM a WHERE id like "%3%";

    #有索引

    #最左前缀原则 有索引
    EXPLAIN SELECT * FROM a WHERE id like "3%";

    #or 有索引

    EXPLAIN SELECT * FROM a WHERE `name` in ('测试_7','测试_8','测试_9','测试_10','测试_11','测试_12''测试_13','测试_14','测试_15','测试_16','测试_17','测试_18');

    #in 有索引

    EXPLAIN SELECT * FROM a WHERE `name` = '测试_7'or name='测试_8'or name='测试_9'or name='测试_10'or name='测试_11'or name='测试_12'or name='测试_13'or name='测试_14'or name='测试_15'or name='测试_16'or name='测试_17'or name='测试_18';

    #复合索引 MySQL组合索引“最左前缀”的结果
    ALTER TABLE jinxudong ADD INDEX name_remark (name(10),remark(255));

    desc jinxudong;
    #索引有效
    EXPLAIN SELECT * FROM jinxudong WHERE `name`='a' AND remark ='a';
    #索引有效
    EXPLAIN SELECT * FROM jinxudong WHERE `name`='a';
    #索引失效
    EXPLAIN SELECT * FROM jinxudong WHERE `remark`='a';
    #有索引 因为有a 最左边原则
    EXPLAIN SELECT * FROM jinxudong WHERE `remark`='a' AND name='a';

    # 举例:给 a b c 建立组合索引 则 a有效 abc有效 ab有效 bc无效 b c 都无效

  • 相关阅读:
    大数据之软件安装(一)-yum源配置
    Python随笔之常用模块-time&datetime模块
    Python随笔之文件操作
    linux 安装 mysql8 (ubuntu)
    让cat命令有颜色得输出文件(ccat)
    VMware Workstation 15 Pro 永久激活密钥
    python常用
    静态代理模式
    mysql常用命令及常见问题
    vue+django 项目 打包
  • 原文地址:https://www.cnblogs.com/coderdxj/p/10018735.html
Copyright © 2011-2022 走看看