博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL里执行SHOW INDEX结果中Cardinality的含义
阅读量:4679 次
发布时间:2019-06-09

本文共 1319 字,大约阅读时间需要 4 分钟。

本文内容遵从, 可以随意转载, 但必须以超链接形式标明文章原始出处和作者信息及版权声明

网址: http://www.penglixun.com/tech/database/mysql_show_index_cardinality.html

今天在写一个Perl脚本,想自动化查找出MySQL数据库中可能无效的索引,于是根据朝阳的书上提到的一些规则,我来设计了一些判断方法,其中发现某个我想要的值就是SHOW INDEX FROM table里的Cardinality,于是查了下它的含义以验证我的想法。

MySQL中SHOW INDEX FROM table 会有以下结果列

| Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment |

我想知道的是Cardinality列的含义。

查看官方文档的解释:
An estimate of the number of unique values in the index. This is updated by running ANALYZE TABLE or myisamchk -a. Cardinality is counted based on statistics stored as integers, so the value is not necessarily exact even for small tables. The higher the cardinality, the greater the chance that MySQL uses the index when doing joins.

所以这个Cardinality会有如下的含义:

1. 列值代表的是此列中存储的唯一值的个数(如果此列为primary key 则值为记录的行数)
2. 列值只是个估计值,并不准确。
3. 列值不会自动更新,需要通过Analyze table来更新一张表或者mysqlcheck -Aa来进行更新整个数据库。
4. 列值的大小影响Join时是否选用这个Index的判断。
5. 创建Index时,MyISAM的表Cardinality的值为null,InnoDB的表Cardinality的值大概为行数。
6. MyISAM与InnoDB对于Cardinality的计算方式不同。

InnoDB中会采用什么计算方式呢?我回家后试一试。

这篇文章介绍很详细:

http://www.mysqlperformanceblog.com/2008/09/03/analyze-myisam-vs-innodb/

 
标签:  ,  , 
 
 
 
 

转载于:https://www.cnblogs.com/seasonzone/p/3441761.html

你可能感兴趣的文章
从App Store上获取已经上架的App版本信息
查看>>
SpringMvc实现日期转换
查看>>
Android稳定性测试之Log分析
查看>>
WPF中使用ObjectDataProvider绑定方法
查看>>
万能数据库查询分析器中文版本《DB查询分析器》几年来在“中关村在线”首次大榜小榜都能够榜上有名...
查看>>
孔明灯-噪点插画
查看>>
类与接口(三)java中的接口与嵌套接口
查看>>
VS关闭Browser Link
查看>>
【题解】山头狙击战
查看>>
USB小白学习之路(3) 通过自定义请求存取外部RAM
查看>>
Solr:通过solr admin对索引库维护<四>
查看>>
mysql写注释的几种方法
查看>>
UPC-2243 军事情报【递推】
查看>>
HTML常用标签查询
查看>>
四方精创前端开发面试经验
查看>>
软件测试作业(一)
查看>>
使用icomoon把svg图片生成字体图标
查看>>
C++中 使用数组作为map容器VAlue值的解决方法
查看>>
mysql left join,right join,inner join用法分析
查看>>
Ewebeditor最新漏洞及漏洞大全
查看>>