优化MySQL前缀索引[通俗易懂]

优化MySQL前缀索引[通俗易懂]文章介绍如何如何创建MySQL前缀索引,以及计算索引的选择性,明确使用前置索引的场景。

大家好,又见面了,我是你们的朋友全栈君。

目标

  1. 明确前缀索引使用场景;
  2. 掌握创建前缀索引的语法;
  3. 掌握计算索引选择性的方法。

定义

    对于字符串列,可以使用语法指定索引前缀长度来创建仅使用列值开头的索引。
    语法:
        CREATE INDEX 自定义索引名称 ON 表名字(字段名(截取该字段的位数));
    举例:
        /*为pharmacy表创建一个名字为name_of_drug_10的前缀索引,这个索引截取了name_of_drug字段的前10位。*/
        CREATE INDEX name_of_drug_10 ON pharmacy (name_of_drug(10));

场景

如果需要对BLOBTEXT类型的列创建索引,则只能创建前缀索引。


使用方法

通过索引选择性来确定前缀索引截取的字节位数,索引的选择性指不重复的索引值与数据总量的比值。索引的选择性越高则查询效率越高,因为选择性更高的索引可以让mysql在查找的时候过滤掉更多的行。

  • 案例
    /*给pharmacy表建立以name_of_drug字段为前缀的索引,先来计算索引选择性。*/
    SELECT 
    COUNT(DISTINCT LEFT(name_of_drug,3))/COUNT(1) AS selectivity3,
    COUNT(DISTINCT LEFT(name_of_drug,4))/COUNT(1) AS selectivity4,
    COUNT(DISTINCT LEFT(name_of_drug,5))/COUNT(1) AS selectivity5,
    COUNT(DISTINCT LEFT(name_of_drug,6))/COUNT(1) AS selectivity6,
    COUNT(DISTINCT LEFT(name_of_drug,7))/COUNT(1) AS selectivity7,
    COUNT(DISTINCT LEFT(name_of_drug,8))/COUNT(1) AS selectivity8, 
    COUNT(DISTINCT LEFT(name_of_drug,9))/COUNT(1) AS selectivity9
    FROM pharmacy;
  • 结果集

优化MySQL前缀索引[通俗易懂]

  • 结论

截取name_of_drug前6个字节进行对比就已经有99.74%的数据不一样了,所以可以选择name_of_drug前6个字节为前缀创建前缀索引:

    CREATE INDEX name_of_drug_6 ON pharmacy (name_of_drug(6));

注意

索引的选择性在80%以上适合建立,否则不建议建立索引,例如性别等。

前缀支持和前缀长度(如果支持)取决于存储引擎。例如,对于InnoDB 使用REDUNDANT 或 COMPACT 行格式的表,前缀的最大长度为767个字节。对于InnoDB使用DYNAMIC或COMPRESSED 行格式的表,前缀长度限制为3072字节。对于MyISAM表,前缀长度限制为1000个字节。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142343.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • aMule 无法登录服务器问题

    aMule 无法登录服务器问题

    2021年5月1日
    156
  • linux下解压rar文件的方法

    linux下解压rar文件的方法
      wgetlinux-3.8.0.tar.gz”>http://www.rarlab.com/rar_CN/rarlinux-3.8.0.tar.gz
      tarxzvfrarlinux-3.8.0.tar.gz
      cdrar
      makeinstall
      rarxfile.rar
      注意:rar目录中的rar文件就是可执行文件,如果没有makeinstall的权限,可以将rar放到PATH环境变量指定的目录中,直接运行r

    2022年7月11日
    17
  • CAS原理分析_单点登录cas原理

    CAS原理分析_单点登录cas原理CAS的英文为CompareandSwap翻译为比较并交换。CAS加volatile关键字是实现并发包的基石。没有CAS就不会有并发包,synchronized是一种独占锁、悲观锁,java.util.concurrent中借助了CAS指令实现了一种区别于synchronized的一种乐观锁。什么是乐观锁与悲观锁?悲观锁:总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所…

    2022年10月17日
    4
  • Server.MapPath详解「建议收藏」

    Server.MapPath详解「建议收藏」语法:Server.Mappath(path)                          //path为你要指定的路径用途:将path指定的虚拟路径转化为实际路径,参数path必须为虚拟路径,否则将出错!范例:1)Server.Mappth(“page.aspx”)      //找出页面page.aspx的实际路径2)Server.Mappth(“/”)     

    2022年7月12日
    13
  • 服务网关配置_服务网关作用

    服务网关配置_服务网关作用目录第一章Gateway介绍1.1、什么是Gateway1.2、为啥用Gateway第二章Gateway三大核心第三章Gateway工作流程第四章Gateway路由功能4.1、项目准备与启动4.2、工程搭建与测试4.3、配置自定义路由4.4、禁止默认的路由4.5、配置动态的路由4.6、用代码来配路由4.7、为下章节做准备第五章Gateway断言功能5.1、谓词:Path5.2、谓词:After5.3、谓词:Before5.4、谓词:Between5.5、谓词:Cookie5.6、谓词:Header

    2022年10月10日
    4
  • reload与refresh

    reload与refreshwindow.reload()是重新加载当前需要的所有内容.window.Refresh()是刷新,保留之前的缓存内容,重新加载页面,之前存在的东西不会动,没加载上来的东西继续加载.

    2022年7月18日
    14

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号