如何配置统计信息
持久化优化持久化统计功能是通过将内存中的统计数据存储到磁盘中,使其在数据库重启时可以快速重新读入这些统计信息而不用重新执行统计,从而使得查询优化器可以利用这些持久化的统计信息准确地选择执行计划(如果没有这些持久化的统计信息,那么数据库重启之后内存中的统计信息将会丢失,下一次访问到某库某表时,需要重新计算统计信息,并且重新计算可能会因为估算值的差异导致查询计划发生变更,从而导致查询性能发生变化)。如何启用统计信息的持久化功能呢?当innodb_stats_persistent = ON时,或者在建表时使用了建表选项STATS_PERSISTENT =1,则表示开启统计信息的持久化功能(注意,后者表示只开启单表的统计信息持久化功能且无论是否启用了innodb_stats_persistent参数,前者代表开启全局所有表的统计信息持久化功能。innodb_stats_persistent系统变量默认是开启的,如果要单独关闭某个表的持久化统计功能,则可以通过ALTER TABLE tbl_name STATS_PERSISTENT = 0语句来修改)。持久化统计信息被存储在mysql.innodb_table_stats和mysql.innodb_index_stats表中,前者存放与表结构、数据行相关的统计信息,后者存放与索引值相关的统计信息。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




