53.39. pg_proc
В каталоге pg_proc хранится информация об обычных функциях, процедурах, агрегатных и оконных функциях (в совокупности также называемых подпрограммами). За дополнительными сведениями обратитесь к описанию CREATE FUNCTION, CREATE PROCEDURE и Разделу 39.3.
Если prokind указывает, что данная запись описывает агрегатную функцию, в pg_aggregate должна быть соответствующая строка.
Таблица 53.39. Столбцы pg_proc
| Имя | Тип | Ссылки | Описание | 
|---|---|---|---|
| oid | oid | Идентификатор строки (скрытый атрибут; должен выбираться явно) | |
| proname | name | Имя функции | |
| pronamespace | oid |  | OID пространства имён, содержащего эту функцию | 
| proowner | oid |  | Владелец функции | 
| prolang | oid |  | Язык реализации или интерфейс вызова для этой функции | 
| procost | float4 | Примерная стоимость выполнения (в единицах cpu_operator_cost); если установлен признак proretset, это стоимость выдачи одной строки | |
| prorows | float4 | Примерное число возвращаемых строк (ноль, если признак proretsetне установлен) | |
| provariadic | oid |  | Тип данных элементов переменного массива параметров, либо 0, если функция не принимает переменное число параметров | 
| protransform | regproc |  | Вызовы этой функции могут быть упрощены заданной функцией (см. Подраздел 39.10.10) | 
| prokind | char | f— обычная функция (Function),p— процедура (Procedure),a— агрегатная функция (Aggregate function) илиw— оконная функция (Window function) | |
| prosecdef | bool | Функция определяет контекст безопасности (т. е. это функция «setuid») | |
| proleakproof | bool | Функция не имеет побочных эффектов. Никакая информация о её аргументах не выдаётся, кроме как через возвращаемое значение. Любая функция, которая может выдать ошибку, в зависимости от значений аргументов, не является герметичной. | |
| proisstrict | bool | Функция возвращает NULL, если любой из аргументов при вызове NULL. В этом случае функция фактически не будет вызываться вовсе. Функции, не являющиеся «строгими», должны быть готовы принять значения NULL. | |
| proretset | bool | Функция возвращает множество (т. е. множество значений указанного типа данных) | |
| provolatile | char | Свойство provolatileговорит, зависит ли результат функции только от её входных аргументов, либо на него влияют внешние факторы. Буквойiобозначаются постоянные функции («immutable»), которые всегда возвращают один результат для одних и тех же аргументов. Буквойsобозначаются стабильные функции («stable»), результаты которых (для одних и тех же аргументов) не меняются в ходе одного сканирования. Буквойvобозначаются изменчивые функции («volatile»), результаты которых могут меняться в любое время. (Так жеvследует выбирать для функций с побочными эффектами, чтобы система не оптимизировала их вызовы.) | |
| proparallel | char | Свойство proparallelговорит, может ли эта функция безопасно выполняться в параллельном режиме. Символомsв нём обозначаются функции, которые могут выполняться в параллельном режиме без ограничений. Символомrобозначаются функции, которые могут выполняться в параллельном режиме, но только в ведущем процессе группы; в параллельных рабочих процессах вызывать их нельзя. Символомuотмечаются функции небезопасные в параллельном режиме; присутствие такой функции влечёт выбор последовательного плана выполнения запроса. | |
| pronargs | int2 | Число входных аргументов | |
| pronargdefaults | int2 | Число аргументов, для которых определены значения по умолчанию | |
| prorettype | oid |  | Тип данных возвращаемого значения | 
| proargtypes | oidvector |  | Массив с типами данных аргументов функции. В нём учитываются только входные аргументы функции (включая аргументы INOUTиVARIADIC), так что он представляет сигнатуру вызова функции. | 
| proallargtypes | oid[] |  | Массив с типами данных аргументов функции. В нём учитываются все аргументы (включая аргументы OUTиINOUT); однако если все аргументы только входные (IN), это поле будет содержать NULL. Заметьте, что индексы в нём начинаются с 1, тогда как вproargtypesпо историческим причинами они начинаются с 0. | 
| proargmodes | char[] | Массив с режимами аргументов функций, закодированными как iдля входных аргументов (IN),oдля выходных аргументов (OUT),bдля аргументов входных и выходных одновременно (INOUT),vдля переменных аргументов (VARIADIC) иtдля табличных аргументов (TABLE). Если все аргументы являются аргументамиIN, это поле может содержать NULL. Заметьте, что индексы в этом массиве соответствуют позициям вproallargtypes, а не вproargtypes. | |
| proargnames | text[] | Массив с именами аргументов функции. Для аргументов без имени в этом массиве задаются пустые строки. Если все аргументы функции безымянные, это поле может содержать NULL. Заметьте, что индексы в этом массиве соответствуют позициям в proallargtypes, а не вproargtypes. | |
| proargdefaults | pg_node_tree | Деревья выражений (в представлении nodeToString()) для значений аргументов по умолчанию. Это список, содержащийpronargdefaultsэлементов, соответствующих последнимNвходным аргументам (т. е., последнимNпозициям вproargtypes). Если значение по умолчанию не имеет никакой аргумент, это поле может содержать NULL. | |
| protrftypes | oid[] | OID типов данных, к которым будут применяться трансформации. | |
| prosrc | text | Это значение говорит обработчику функции, как вызывать данную функцию. Это может быть собственно исходный код функции для интерпретируемых языков, объектный символ, имя файла или что-то другое, в зависимости от языка реализации/соглашения о вызовах. | |
| probin | text | Дополнительная информация о том, как вызывать функцию. Интерпретация этого значения так же зависит от языка. | |
| proconfig | text[] | Локальные присваивания конфигурационных переменных времени выполнения, действующие в рамках функции | |
| proacl | aclitem[] | Права доступа; за подробностями обратитесь к описанию GRANT и REVOKE | 
Для скомпилированных функций, как встроенных, так и динамически загружаемых, поле prosrc содержит имя функции на языке C (объектный символ). Для всех других известных сегодня языков поле prosrc содержит исходный код функции. Поле probin используется только для динамически загружаемых функций на C, для которых оно задаёт имя разделяемой библиотеки, содержащей эти функции.