https://blog.csdn.net/afsvsv/article/details/84998119
https://www.toutiao.com/i6633207458275787268/?tt_from=weixin&utm_campaign=client_share&wxshare_count=2&from=singlemessage×tamp=1544497057&app=news_article&utm_source=weixin&iid=36618779372&utm_medium=toutiao_android&group_id=6633207458275787268&pbid=6634051816228275726
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;
当前缀的选择性越接近全列选择性的时候,索引效果越好。