zoukankan      html  css  js  c++  java
  • MySQL单表数据量过千万,采坑优化记录,完美解决方案

     

     ——————————————————————————————————————————————————————————————————————————————————————————
    原文链接:https://blog.csdn.net/csdn_am/article/details/79880856

    mysql创建前缀索引
    原创金字塔的旅行 最后发布于2018-04-10 14:33:05 阅读数 2647 收藏
    展开
    ALTER table 表名 add index title_pre(列名(100))

    列名后面的数字代表前缀的长度,前缀长度并不是越长越好,这里涉及到一个选择性问题,

    select count(distinct 列名)/count(*)as a,COUNT(DISTINCT left(列名,100)) as b, COUNT(DISTINCT left(列名,110)) as c from 表名

    来查看选择性高低,选择性越高代表索引价值越高
    ———————————————————————————————————————————————————————————————————————————————————————————

    Mysql前缀索引长度确定方法

    MySQL 前缀索引能有效减小索引文件的大小,提高索引的速度。但是前缀索引也有它的坏处:MySQL 不能在 ORDER BY 或 GROUP BY 中使用前缀索引,也不能把它们用作覆盖索引(Covering Index)。

    添加语法:ALTER TABLE table_name ADD KEY(column_name(prefix_length));

    在MySQL中,前缀长度最大值为255字节。对于存储引擎为MyISAM或InnoDB的数据表,前缀最长为1000字节。 必须注意的是,在MySQL中,对于TEXT和BLOB这种大数据类型的字段,必须给出前缀长度(length)才能成功创建索引。

    如何确定前缀索引长度?
    可以通过计算选择性来确定前缀索引的选择性,计算方法如下
    全列选择性:
    SELECT COUNT(DISTINCT column_name) / COUNT(*) FROM table_name;
    某一长度前缀的选择性
    SELECT COUNT(DISTINCT LEFT(column_name, prefix_length)) / COUNT(*) FROM table_name;
    当前缀的选择性越接近全列选择性的时候,索引效果越好。

    参考文章:
    MySQL索引操作命令详解
    MySQL 前缀索引

    _____________________________________________________________________————————————————————————————————————————————————————

    计算适合设置索引的长度,直到去重以后在一个固定值。

    根据去重以后适合的长度设置索引。

    计划查询

     
    分类: Mysql
  • 相关阅读:
    JVM01---简介
    SpringBoot-01创建项目,实例
    git的三种提交方式(目前两种)
    Spring-事务
    JDK及CGLIB动态代理-AOP4种增强
    Spring-静态代理
    Spring-Aop
    初识jvm-1.Java类的加载机制
    java公开课-06-实用类
    java公开课-05-集合及Socket网络编程(简介)
  • 原文地址:https://www.cnblogs.com/kelelipeng/p/12598069.html
Copyright © 2011-2022 走看看