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

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

    《欢迎交流讨论》

  • 相关阅读:
    js 模拟表单提交下载文件
    vue 刷新子组件方法解决使用v-if闪屏问题
    Java15-Tomcat&Servlet&HTTP&Request&Response
    JAVA26-SpringBoot-在线教育项目01
    20 Vue-ajax
    19 Vue-JQuery
    18 Vue-Json
    Java 20-Mybatis学习
    17 Vue-ES6语法之Promise、VueX、网络请求封装
    16 Vue-cli脚手架介绍与使用
  • 原文地址:https://www.cnblogs.com/chenmh/p/5629448.html
Copyright © 2011-2022 走看看