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
  • 相关阅读:
    PowerDesigner11.0的SQL生成表,写列描述出错
    centos中crontab(计时器)用法详解
    5.14
    4.13
    5.15
    监听服务启动失败
    4.24
    Enjoy 4.26
    4.14
    export
  • 原文地址:https://www.cnblogs.com/kelelipeng/p/12598069.html
Copyright © 2011-2022 走看看