zoukankan      html  css  js  c++  java
  • 什么是统计信息以及收集查看方法

    概念:
    oracle的统计信息:存储在数据字典里,且从多个维度描写叙述了Oracle数据库里对象的具体信息。CBO会利用这些统计信息来计算各条路径的成本。

    分类:
    表、索引、列、系统、数据字典、内部对象的统计信息

    收集统计信息:
    ANALYZE 命令和DBMS_STATS包。表、索引、列、数据字典都能够用两个系统、内部对象仅仅能用DBMS_STATS。


    1、ANALYZE 
    analyze table PROC_PROGRESS_LOG delete statistics; --删除统计信息
    analyze table PROC_PROGRESS_LOG estimate statistics sample 15 percent for table ; --估算模式。採样比例15%(估算结果和实际结果不一定会全然匹配)
    analyze table PROC_PROGRESS_LOG compute statistics;--计算模式

    select * from dba_tables where table_name = 'PROC_PROGRESS_LOG'; --查看表相关信息
    select * from USER_TAB_COLUMNS where TABLE_NAME='PROC_PROGRESS_LOG'--查看列相关信息

    analyze table PROC_SMCS compute statistics for columns service_id , channel_id ; --对列进行计算模式的统计信息收集
    运行完毕之后。service_id , channel_id 确实已经有统计信息了。可是PROC_SMCS 表中的统计信息将会被抹掉。
    也就是说,对同一个对象而言。新运行的analyze 命令会抹掉之前的analyze 的结果。

    假设想一次性以计算模式收集表、表上的列、和表上的索引的统计信息。运行:
    analyze table PROC_PROGRESS_LOG compute statistics;

    用DBMS_STATS包收集统计信息
    官方推荐。oracle 8.1.5之后才有,看成是analyze的增强版
    1、GATHER_TABLE_STATS:用于收集目标表、目标表的列和索引的统计信息。
    2、GATHER_INDEX_STATS:收集索引的。
    3、GATHER_SCHEMA_STATS:收集指定schema下的全部对象的。
    4、GATHER_DATABASE_STATS:收集全库全部对象的。

    exec dbms_stats.gather_table_stats(ownname => 'TEST',tabname=>'PROC_LETTER',estimate_percent => 15,method_opt => 'FOR TABLE',cascade => false);
    仅仅有PROC_LETTER表有统计信息。列和索引没有。
    method_opt => 'FOR TABLE' 仅仅适合11g以上版本号,10下面的,还会收集列和索引的信息。

    假设採用计算模式。将estimate_percent => 15 设置成100或者NULL

    exec dbms_stats.gather_table_stats(ownname => 'TEST',tabname=>'PROC_LETTER',estimate_percent => 100,method_opt => 'FOR columns size 1 service_id channel_id',cascade => false);
    以计算模式收集 service_id channel_id的统计信息,同一时候PROC_LETTER表上也会有统计信息。

    DBMS_STATS做不到仅仅收集列的统计信息而不收集表的统计信息。

    exec dbms_stats.delete_table_stats(ownname => 'TEST' , tabname => 'PROC_LETTER');
    删除统计信息。


    exec dbms_stats.gather_table_stats(ownname => 'TEST',tabname=>'PROC_LETTER',estimate_percent => 100,cascade => false); 
    一次性统计表、列、索引信息。


    analyze 和 dbms_stats的差别:
    1、analyze 不能正确收集分区表的统计信息,而dbms_stats能够。

    2、analyze 不能并行收集统计信息,而dbms_stats能够。
    exec dbms_stats.gather_table_stats(ownname => 'TEST',tabname=>'PROC_LETTER',estimate_percent => 100,cascade => false,degree=4); --并行度为4
    3、dbms_stats不能收集与CBO无关的额外信息。如行迁移/行链接的数量、校验表和索引的结构信息。
    analyze table XXX list chained rows into YYY --分析收集行迁移/行链接的数量
    analyze index XXX validate structure 分析索引的结构
  • 相关阅读:
    页面生命周期
    设计模式
    算法
    window服务
    Xml
    sql声明变量,及if else语句、while语句的用法
    SQL 使用临时表和临时变量完成update表字段实际案例
    SQL Server遍历表的几种方法
    node快速构建express项目
    词法分析
  • 原文地址:https://www.cnblogs.com/tlnshuju/p/6727354.html
Copyright © 2011-2022 走看看