49.75. pg_stats

Представление pg_stats открывает доступ к информации, хранящейся в каталоге pg_statistic. Это представление даёт доступ только к тем строкам каталога pg_statistic, что соответствуют таблицам, которые пользователь может читать, таким образом это представление можно безопасно разрешить читать всем.

Кроме того, представление pg_stats сконструировано так, чтобы представлять информацию в более понятном формате, чем нижележащий каталог — ценой того, что его схему приходится расширять всякий раз, когда для pg_statistic определяются новые типы слотов.

Таблица 49-76. Столбцы pg_stats

ИмяТипСсылкиОписание
schemaname name pg_namespace.nspname Имя схемы, содержащей таблицу
tablename name pg_class.relname Имя таблицы
attname name pg_attribute.attname Имя столбца, описываемого этой строкой
inherited bool  Если true, в данных этой строки учитываются значения в дочерних столбцах, а не только в указанной таблице
null_frac real  Доля записей, в которых этот столбец содержит NULL
avg_width integer  Средний размер элементов в столбце, в байтах
n_distinct real  Число, большее нуля, представляет примерное количество различных значений в столбце. Если это число меньше нуля, его модуль представляет количество различных значений, делённое на количество строк. (Отрицательная форма применяется, когда ANALYZE полагает, что число различных значений, скорее всего, будет расти по мере роста таблицы; положительная, когда в столбце, вероятно, будет фиксированное количество возможных значений.) Например, -1 указывает на столбец с уникальным содержимым, в котором количество различных значений совпадает с количеством строк.
most_common_vals anyarray  Список самых частых значений в столбце. (NULL, если не находятся значения, появляющиеся чаще других.)
most_common_freqs real[]  Список частот самых частых значений, то есть число их вхождений, делённое на общее количество строк. (NULL, вместе с most_common_vals.)
histogram_bounds anyarray  Список значений, разделяющих значения столбца на примерно одинаковые популяции. Значения most_common_vals, если они присутствуют, не рассматриваются при вычислении этой гистограммы. (Этот столбец содержит NULL, если для типа данных столбца не определён оператор <, либо если в most_common_vals перечисляется вся популяция.)
correlation real  Статистическая корреляция между физическим порядком строк и логическим порядком значений столбца. Допустимые значения лежат в диапазоне -1 .. +1. Когда значение около -1 или +1, сканирование индекса по столбцу будет считаться дешевле, чем когда это значение около нуля, как результат уменьшения случайного доступа к диску. (Этот столбец содержит NULL, если для типа данных столбца не определён оператор <.)
most_common_elems anyarray  Список элементов, отличных от NULL, наиболее часто присутствующих в значениях столбца. (NULL для скалярных типов.)
most_common_elem_freqs real[]  Список частот самых частых элементов, то есть доля строк, содержащих минимум один экземпляр данного значения. За частотами по элементам следуют два или три дополнительных значения: минимум и максимум предшествующих частот по элементам и дополнительно частота элементов NULL. (Принимает значение NULL вместе с most_common_elems.)
elem_count_histogram real[]  Гистограмма количеств различных и отличных от NULL элементов в значениях этого столбца, за которой следует среднее количество элементов, отличных от NULL. (Принимает значение NULL для скалярных типов.)

Максимальным числом записей в полях-массивах можно управлять на уровне столбцов, используя команду ALTER TABLE SET STATISTICS, или глобально, задав параметр времени выполнения default_statistics_target.