On Tue, 2025-07-29 at 06:46 -0500, Igor Korot wrote: > SELECT > t.relname AS table_name, > i.relname AS index_name, > a.attname AS column_name > FROM > pg_class t, > pg_class i, > pg_index ix, > pg_attribute a > WHERE > t.oid = ix.indrelid AND > i.oid = ix.indexrelid AND > a.attrelid = t.oid AND > a.attnum = ANY(ix.indkey) AND > t.relkind = 'r' AND -- 'r' for regular table > t.relname = 'your_table_name' -- Optional: filter by table name > ORDER BY > t.relname, > i.relname, > a.attnum; > > I can build on top of this query, however I have 2 issues: > > First and most important one - they are filtering by just table name. > How can I filter by the fully qualified name - catalog.schema.table?
"catalog" is irrelevant, since PostgreSQL doesn't allow cross-database queries. To add a filter for the schema, use AND t.relnamespace = 'schemaname'::regnamespace > Second - how cn I get the partial index condition? Either the whole > WHERE clause (which I will have to parse) > or the broken down one (field, condition {AND|OR} field, condition}? SELECT pg_get_expr(ix.indpred, t.oid) Yours, Laurenz Albe