MySQL5.5中怎么统计信息且收集
发布时间:2022-01-19 06:16:18 所属栏目:编程 来源:互联网
导读:本篇内容主要讲解MySQL5.5中怎么统计信息并收集,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习MySQL5.5中怎么统计信息并收集吧! 对于大表来说,需要手动添加 ANALYZE TABLE 表名 的定时收集任务。 在 MySQL 中
本篇内容主要讲解“MySQL5.5中怎么统计信息并收集”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL5.5中怎么统计信息并收集”吧! 对于大表来说,需要手动添加 ANALYZE TABLE 表名 的定时收集任务。 在 MySQL 中,查询优化器基于统计信息来选择合适的执行计划。 统计信息的主要部分如下: ① cardinality,表中非重复行的条目 ② 表的总行数 ③ 索引 对于表的数据,通过主键索引来代表; 对于索引的条目,通过第二索引来代表 下面的操作会导致 InnoDB 来对表中的每个索引进行随机采样数据页: ① ANALYZE TABLE 语句 ② SHOW TABLE STATUS 语句 ③ 数据库重启后,对表的第一次访问 innodb_stats_on_metadata 参数设置成 ON,则数据库会将统计信息存储到系统表中 >show global variables like 'innodb_stats_on_metadata'; +--------------------------+-------+ | Variable_name | Value | +--------------------------+-------+ | innodb_stats_on_metadata | ON | +--------------------------+-------+ 1 row in set (0.00 sec) 对于空值的处理,可以通过 innodb_stats_method 参数来配置 >show global variables like 'innodb_stats_method'; +---------------------+-------------+ | Variable_name | Value | +---------------------+-------------+ | innodb_stats_method | nulls_equal | +---------------------+-------------+ 1 row in set (0.00 sec) 其他的统计信息,可以在 INFORMATION_SCHEMA、PERFORMANCE_SCHEMA 库下的表来获取 为了提供统计信息收集时的采样精度,可以调整 innodb_stats_sample_pages 参数 这个参数的默认值是 8,对于大表来说,这个默认值是不够的,需要增大 >show global variables like 'innodb_stats_sample_pages'; +---------------------------+-------+ | Variable_name | Value | +---------------------------+-------+ | innodb_stats_sample_pages | 8 | +---------------------------+-------+ 1 row in set (0.00 sec) 到此,相信大家对“MySQL5.5中怎么统计信息并收集”有了更深的了解,不妨来实际操作一番吧! (编辑:广西网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐