在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
一、基数是啥? 如果这一类是唯一索引,那基数 = 行数。 如果这一列是sex,枚举类型只有男女,那它是基数就是2 Cardinality越高,列就越有成为索引的价值。MySQL执行计划也会基于Cardinality选择索引。 通过下面的方式可以看到表中各列的基数。 比如这个经典的例子: 二、InnoDB更新基数的时机? 三、基数是估算出来 基数并不会实时更新!而且它是通过采样估算出来的值! 至于基数的公式是怎样的,可能并不重要。 重要的是你得知道,他是通过随机采样数据页的方式统计出来的一个估算值。 而且随机采样的页数可以通过参数innodb_stats_persistent_sample_pages 设置,默认值是20。
四、持久化基数 可以通过参数innodb_stats_persistent 控制是否持久化基数,默认为off。 当然你可以为一个单独的表设置 STATS_PERSISTENT=1 那么它的 innodb_stats_persistent将自动被启用。 开启它的好处是:重启MySQL不会再重复计算这个值,加快重启速度。 五、如何主动更新基数? 执行下面的SQL时都会触发InnoDB更新基数(即使你并没有意识到它会更新基数)。 所以尽量选择一个业务低峰期 analyze table tableName; 如果因为采样的数量太少了,计算的基数错的离谱。那很可能会导致MySQL的优化器选错索引。这是你可以将这个值适当调大。但是增加 太多可能会导致 ANALYZE TABLE运行缓慢。 反之, ANALYZE TABLE运行太慢。你可以适度调整参数innodb_stats_persistent_sample_pages 的值。但是这又可能导致基数计算的不准确。
参考: https://dev.mysql.com/doc/refman/5.7/en/innodb-persistent-stats.html https://dev.mysql.com/doc/refman/5.7/en/innodb-analyze-table-complexity.html 以上就是浅析MySQL的基数统计的详细内容,更多关于MySQL 基数统计的资料请关注极客世界其它相关文章! |
请发表评论