本章节主要介绍PolarDB PostgreSQL版(兼容Oracle)中的不同视图详细信息,可通过查询不同视图获取相关对象信息,进而方便定位性能问题。

  • pg_stat_all_tables
    pg_stat_all_tables视图将为当前数据库中的每一个表显示与该表访问相关的统计信息。相关参数说明如下表所示:
    参数类型描述
    relidoid表OID。
    schemanamename表所在的Schema的名称。
    relnamename表名称。
    seq_scanbigint在表上发起的顺序扫描的次数。
    seq_tup_readbigint被顺序扫描取得的活着的行的数量。
    idx_scanbigint在表上发起的索引扫描的次数。
    idx_tup_fetchbigint被索引扫描取得的活着的行的数量。
    n_tup_insbigint被插入的行数。
    n_tup_updbigint被更新的行数(包括 HOT 更新的行)。
    n_tup_delbigint被删除的行数。
    n_tup_hot_updbigint被更新的 HOT 行数(即不要求独立索引更新的行更新)。
    n_live_tupbigint活着的行的估计数量。
    n_dead_tupbigint死亡行的估计数量。
    n_mod_since_analyzebigint从表最近一次被分析后被修改的行的估计数量。
    last_vacuumtimestamp with time zone最近一次表被手动清理的时间(不统计VACUUM FULL)。
    last_autovacuumtimestamp with time zone最近一次表被自动清理守护进程清理的时间。
    last_analyzetimestamp with time zone最近一次表被手动分析的时间。
    last_autoanalyzetimestamp with time zone最近一次表被自动清理守护进程分析的时间。
    vacuum_countbigint表被手工清理的次数(不统计VACUUM FULL)。
    autovacuum_countbigint表被自动清理守护进程清理的次数。
    analyze_countbigint表被手工分析的次数。
    autoanalyze_countbigint表被自动清理守护进程分析的次数。
  • pg_statio_all_tables
    pg_statio_all_tables视图将为当前数据库中的每个表指定有关 I/O 的统计信息。相关参数说明如下表所示:
    参数类型描述
    relidoid表的 OID。
    schemanamename表所在的Schema的名称。
    relnamename表的名称。
    heap_blks_readbigint从表读取的磁盘块数量。
    heap_blks_hitbigint在表中的缓冲区命中数量。
    idx_blks_readbigint从表上所有索引中读取的磁盘块数。
    idx_blks_hitbigint在表上的所有索引中的缓冲区命中数量。
    toast_blks_readbigint从表的 TOAST 表读取的磁盘块数。
    toast_blks_hitbigint在表的 TOAST 表中的缓冲区命中数量。
    tidx_blks_readbigint从表的 TOAST 表索引中读取的磁盘块数。
    tidx_blks_hitbigint在表的 TOAST 表索引中的缓冲区命中数量。

索引

  • pg_stat_all_indexes

    通过查询pg_stat_all_indexes视图可以显示当前数据库中的每个索引访问的统计信息。

    索引可以被简单扫描、位图扫描以及通过优化器来访问。在一次位图扫描中,多个索引的输出可以通过 AND 或 OR 规则组合,当使用一次位图扫描时不能将取得的个体与特定的索引关联起来。因此,一次位图扫描会增加它使用的索引的pg_stat_all_indexes.idx_tup_read数量,并且为每个表增加pg_stat_all_tables.idx_tup_fetch数量,但是它不影响pg_stat_all_indexes.idx_tup_fetch。如果所提供的常量值不在优化器统计信息记录的范围之内,优化器也会访问索引来检查。
    参数类型描述
    relidoid索引基表OID。
    indexrelidoid索引OID。
    schemanamename索引所在的Schema的名称。
    relnamename索引基表的名称。
    indexrelnamename索引名称。
    idx_scanbigint在索引上发起的索引扫描次数。
    idx_tup_readbigint在索引上由扫描返回的索引项数量。
    idx_tup_fetchbigint被使用索引的简单索引扫描取得的活着的表行数量。
  • pg_statio_all_indexes
    显示当前数据库中每个索引的磁盘块读取总数和缓冲区命中总数,以及指定索引上与 I/O 有关的统计信息。相关参数说明如下:
    参数类型描述
    relidoid索引基表的 OID。
    indexrelidoid索引OID。
    schemanamename索引所在Schema的名称。
    relnamename索引基表的名称。
    indexrelnamename索引名称。
    idx_blks_readbigint从索引读取的磁盘块数。
    idx_blks_hitbigint在索引中的缓冲区命中数量。

序列

pg_statio_all_sequences

显示当前数据库相关序列信息,以及指定序列上与 I/O 有关的统计信息。相关参数说明如下:
参数类型描述
relidoid序列OID。
schemanamename序列所在的Schema的名称。
relnamename序列名称。
blks_readbigint从序列中读取的磁盘块数。
blks_hitbigint在序列中的缓冲区命中数量。

函数

pg_stat_user_functions

显示被跟踪函数有关的统计信息。
参数类型描述
funcidoid函数OID。
schemanamename函数所在的Schema名称。
funcnamename函数名称。
callsbigint函数被调用的次数。
total_timedouble precision在函数以及它所调用的其他函数中花费的总时间。单位:毫秒。
self_timedouble precision在函数本身花费的总时间,不包括被它调用的其他函数。单位:毫秒。