[英]List all foreign keys PostgreSQL
I need a query that returns:我需要一个返回的查询:
"table_name", "field_name", "field_type", "contraint_name" “table_name”、“field_name”、“field_type”、“contraint_name”
until now i have:直到现在我有:
select conrelid::regclass AS table_name,
regexp_replace(pg_get_constraintdef(c.oid), '.*\((.*)\)', '\1') as fields,
conname as contraint_name
from pg_constraint c
join pg_namespace n ON n.oid = c.connamespace
join pg_attribute at on
--join pg_type t ON t.typnamespace = n.oid
where contype ='f'
A foreign key may be based on multiple columns, so conkey
and confkey
of pg_constraint
are arrays.一个外键可能基于多个列,所以conkey
的pg_constraint
confkey
数组。 You have to unnest the arrays to get a list of column names or types.您必须取消嵌套数组才能获得列名或类型的列表。 You can use these functions:您可以使用以下功能:
create or replace function get_col_names(rel regclass, cols int2[])
returns text language sql as $$
select string_agg(attname, ', ' order by ordinality)
from pg_attribute,
unnest(cols) with ordinality
where attrelid = rel
and attnum = unnest
$$;
create or replace function get_col_types(rel regclass, cols int2[])
returns text language sql as $$
select string_agg(typname, ', ' order by ordinality)
from pg_attribute a
join pg_type t on t.oid = atttypid,
unnest(cols) with ordinality
where attrelid = rel
and attnum = unnest
$$;
The functions may be very handy when querying constraints and indexes.这些函数在查询约束和索引时可能非常方便。 Your query is nice and simple with them:您的查询对他们来说既好又简单:
select
conrelid::regclass,
get_col_names(conrelid, conkey) col_names,
get_col_types(conrelid, conkey) col_types,
conname
from pg_constraint
where contype ='f';
conrelid | col_names | col_types | conname
----------+-----------+-----------+------------------------
products | image_id | int4 | products_image_id_fkey
(1 row)
SELECT * FROM information_schema.table_constraints
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.