These are tools that make it easier to interface with the Postgres catalog tables/views/functions. They are meant for use by code, not by people.
To make use of them, you need to grant cat_tools__usage to any roles that need access.
|
Warning
|
Any function or view in this extension that exposes raw PostgreSQL catalog
information does not provide a stable API. The PostgreSQL system catalogs
change between major versions — columns are added, removed, and change type.
If your code depends on the specific columns returned by objects such as
|
This is very much a work in progress. If it doesn’t do something you need, please open an issue!
-
object_type- Descriptive names for every type of Postgres object (table, operator, rule, etc) -
constraint_type- Types of constraints (domain constraintortable_constraint) -
relation_type- Types of objects stored inpg_class -
relation_relkind- Valid values forpg_class.relkind
-
currval(table, column)- Returns current value for a sequence owned by a column -
enum_range(regtype)- Returns valid values for an ENUM as an array -
enum_range_srf(regtype)- Returns valid values for an ENUM as a recordset -
name__check(text)- Throws an error if input would be truncated when cast to name -
pg_class(relation regclass)- Returns pg_class_v row for a relation -
pg_extension__get(extension_name name)- Returns pg_extension_v row for an extension -
extension__schemas(extension_names text/name[])- Returns the schemas for the requested functions -
extension__schemas_unique(extension_names text/name[])- Returns a unique array of schemas -
function__arg_types(arguments)- Accepts full function argument string and returns regtype[] of IN/INOUT arguments -
functionarg_types_text(arguments)- Version offunctionarg_typesthat returns text -
object__catalog(object_type)- Returns catalog table that is used to storeobject_typeobjects -
object__reg_type(object_catalog)- Returns the "reg" pseudotype (ie: regclass) associated with a system catalog (ie: pg_class) -
regprocedure(function_name, arguments)- Returns regprocedure for function_name and it’s full set of arguments -
relation__kind(relkind)- Mapping frompg_class.relkindto arelation_type -
relation__relkind(relation_type)- Mapping fromrelation_typeto apg_class.relkindvalue -
triggerargs_as_text(text)- Converts the arguments for a trigger function (as returned bytriggerparse()) to text (for backwards compatibility). -
trigger__get_oid(trigger_table, trigger_name)- oid of a trigger. Throws error if trigger doesn’t exits. -
triggerget_oidloose(trigger_table, trigger_name)- oid of a trigger. Does not throw error if trigger doesn’t exits. -
trigger__parse(trigger oid)- Returns information about a trigger -
trigger__parse(table_name regclass, trigger_name text)- Returns information about a trigger
|
Warning
|
These views may eventually move into a separate extension! |
-
pg_class_v- Joins pg_class to pg_namespace -
pg_extension_v- Joins pg_extension to pg_namespace; cast extconfig to regclass[] -
column- Returns data about columns -
pg_all_foreign_keys- Data about foreign keys
Cat Tools is released under a MIT license.
Copyright (c) 2016 Jim Nasby <Jim.Nasby@BlueTreble.com>.
