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
posted @ 2020-03-30 13:36  kelelipeng  阅读(1002)  评论(0编辑  收藏  举报