PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Wymień wszystkie nazwy indeksów, nazwy kolumn i ich nazwę tabeli bazy danych PostgreSQL

Spowoduje to wyświetlenie wszystkich indeksów ze szczegółami (wyodrębnionymi z moich definicji widoku):

SELECT i.relname as indname,
       i.relowner as indowner,
       idx.indrelid::regclass,
       am.amname as indam,
       idx.indkey,
       ARRAY(
       SELECT pg_get_indexdef(idx.indexrelid, k + 1, true)
       FROM generate_subscripts(idx.indkey, 1) as k
       ORDER BY k
       ) as indkey_names,
       idx.indexprs IS NOT NULL as indexprs,
       idx.indpred IS NOT NULL as indpred
FROM   pg_index as idx
JOIN   pg_class as i
ON     i.oid = idx.indexrelid
JOIN   pg_am as am
ON     i.relam = am.oid;

Opcjonalnie dodaj dodatkowe sprzężenie na końcu, aby przyciąć przestrzenie nazw:

SELECT i.relname as indname,
       i.relowner as indowner,
       idx.indrelid::regclass,
       am.amname as indam,
       idx.indkey,
       ARRAY(
       SELECT pg_get_indexdef(idx.indexrelid, k + 1, true)
       FROM generate_subscripts(idx.indkey, 1) as k
       ORDER BY k
       ) as indkey_names,
       idx.indexprs IS NOT NULL as indexprs,
       idx.indpred IS NOT NULL as indpred
FROM   pg_index as idx
JOIN   pg_class as i
ON     i.oid = idx.indexrelid
JOIN   pg_am as am
ON     i.relam = am.oid
JOIN   pg_namespace as ns
ON     ns.oid = i.relnamespace
AND    ns.nspname = ANY(current_schemas(false));


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Co nowego w PgBouncerze 1.6

  2. Jak przełączać bazy danych w postgresie?

  3. Hibernacja + PostgreSQL + Typ adresu sieciowego (inet, cdir)

  4. Eksportowanie bazy danych PostgreSQL za pomocą phpPgAdmin

  5. Jak usunąć ustaloną liczbę wierszy z sortowaniem w PostgreSQL?