linux mysql 统计_MySQL 统计数据

统计数据的重要性相信了解Oracle数据库的都非常清楚,他是生成执行计划的唯一标准,所以统计数据是否准确直接影响到执行计划的正确性, 关于MySQL虽然没有ORACLE那么多维度的统计数据(比如直方图)但是还是有的,MYSQL 5.6后分为2种统计数据。

1、永久化的统计数据

默认的5.6.6后使用时这种方式,影响他的参数有

innodb_stats_persistent_sample_pages 每次采样的块数,默认为20

innodb_stats_auto_recalc 是否开启自动收集,默认为修改量超过10%的数据

innodb_stats_persistent  默认为ON,是否使用永久化的统计数据

永久化的统计数据存储在innodb_index_stats和innodb_table_stats中,官方文档说统计数据并非实时的,也就是收集统计数据会滞后几分钟,如果想要及时的更新统计

数据需要手动执行ANALYZE TABLE(In some cases, statistics

recalculation may be delayed by a few seconds. If up-to-date statistics are

required immediately after changing significant portions of a table, run ANALYZE

TABLEto initiate a synchronous (foreground) recalculation of statistics)

如果统计数据不准可能需要修改innodb_stats_persistent_sample_pages的值更大,如果analyze table过慢可以考虑减少innodb_stats_persistent_sample_pages的值更小。这两个表为INNODB的表

2、非永久化的统计数

如果设置innodb_stats_persistent为OFF就使用这种方式的统计数据,这种方式的统计数据在数据库重启后就丢失,他的统计数据保存在STATISTICS,TABLES两个表中,他们是MEMORY引擎的表,这种方式受影响的参数

innodb_stats_persistent 设置为OFF

innodb_stats_transient_sample_pages 默认为8,为采样块数

innodb_stats_on_metadata 英文描述To have statistics updated when metadata statements such as SHOW TABLE STATUS

or SHOW INDEX are run, or when accessing the INFORMATION_SCHEMA.TABLES or

INFORMATION_SCHEMA.STATISTICSt ables, execute the statement SET GLOBAL

innodb_stats_on_metadata=ON

当innodb_stats_persistent设置为ON的时候,默认innodb_stats_on_metadata是OFF的,因为它会影响SHOW TABLE STATUS等的速度

最后我们再来简单描述一下ORCALE的统计数据收集的策略,ORACLE 10G,11G都是通过自动化的作业来收集,默认的11G周1到周5晚上10点开始收集统计数据,周末则是早上6点开始,当然这种收集统计数据并不是全部收集,ORACLE会把修改数量超过10%的TABLES记录到mon_mods_all$内部表中,然后对这些表进行收集,这样来保证统计数据能够尽可能的描述数据的分布,同时ORACLE会通过谓词的使用来判定是否收集直方图, 谓词的使用记录在COL_USAGE$内部视图中,直方图用于判定数据的倾斜,MYSQL在这方面视乎还没有。

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值