zoukankan      html  css  js  c++  java
  • MySQL 统计信息

    介绍

    数据库维护统计信息的目的主要是为了优化器进行更好的执行优化,首先统计信息是建立在索引的基础上,如果表没有索引那么该表也就无统计信息。

    系统如何收集统计信息  

    一、手动  

    1.执行Analyze table 

    innodb和mysiam存储引擎都可以通过执行“Analyze table tablename”来收集表的统计信息,除非执行计划不准确,否则不要轻易执行该操作,如果是很大的表该操作会影响表的性能。

    二、自动触发

    以下行为会自动触发统计信息的收集

    1.第一次打开表的时候

    2.表修改的行超过1/6或者20亿条时

    3.当有新的记录插入时

    4.执行show index from tablename或者执行show table、查询information_schema.tablesstatistics 时

    三、开启参数innodb_stats_on_metadata

    当开启参数innodb_stats_on_metadata后访问以下表也会触发统计信息的收集

    在访问以下表时,innodb表的统计信息可自动收集

    information_schema.TABLES
    
    information_schema.STATISTICS
    
    information_schema.PARTITIONS
    
    information_schema.KEY_COLUMN_USAGE
    
    information_schema.TABLE_CONSTRAINTS
    
    information_schema.REFERENTIAL_CONSTRAINTS
    
    information_schema.table_constraints

    参数说明:

    Innodb_stats_sample_pages:每次收集统计信息时采样的页数,默认为20

    innodb_stats_persistent:默认on,将analyze table产生的统计信息保存于磁盘,直至下次analyze table为止,此举避免了统计信息动态更新,保证了执行计划的稳定,对于大表也节省了收集统计信息的所需资源;

    总结


    备注:

        作者:pursuer.chen

        博客:http://www.cnblogs.com/chenmh

    本站点所有随笔都是原创,欢迎大家转载;但转载时必须注明文章来源,且在文章开头明显处给明链接。

    《欢迎交流讨论》

  • 相关阅读:
    不要对父母说的十句话
    25句世界上最經典的話
    奥巴马(Obama)获胜演讲全文[中英对照]+高清视频下载
    【心理测试】男人眼中女人哪里最性感?
    一张图看出你是用左脑还是右脑
    我是有原则的~~(笑话转贴)
    各行各业常用大用大谎言
    你知道我今天为啥要来上班吗?
    女性抽烟腰会变粗?
    心理学家揭秘人临死时的感受
  • 原文地址:https://www.cnblogs.com/chenmh/p/5629448.html
Copyright © 2011-2022 走看看