Eu preciso obter metadados sobre todas as colunas MATERIALIZED VIEW, incluindo seu tipo de dados. Eu posso fazer isso com esta consulta:
SELECT
trim(leading '_' from pg_type.typname) as data_type,
pg_namespace.nspname as schema_name,
pg_namespace.nspname as udt_name,
attnum AS ordinal_position,
pg_attribute.attname as column_name,
pg_class.relname as matview_name,
'-------' AS spacer,
*
from pg_catalog.pg_attribute
join pg_catalog.pg_class ON pg_class.oid = pg_attribute.attrelid
join pg_catalog.pg_namespace ON pg_namespace.oid = pg_class.relnamespace
join pg_catalog.pg_type ON pg_type.typelem = pg_attribute.atttypid
where
pg_class.relkind = 'm' AND
not pg_attribute.attisdropped and
cast(pg_type.typanalyze as text) = 'array_typanalyze' and
pg_attribute.attnum > 0
order by
pg_attribute.attnum
No entanto, ele não lista nenhuma coluna de matriz, devido a elas não existirem na pg_catalog.pg_type
tabela (que é a tabela da qual estou obtendo os tipos de dados).
Como também posso obter metadados (incluindo tipo) para colunas de matriz também?
Estou usando o postgres 13.3.