Heim >Datenbank >MySQL-Tutorial >Wie rufe ich indizierte Spalteninformationen in PostgreSQL ab?

Wie rufe ich indizierte Spalteninformationen in PostgreSQL ab?

Linda Hamilton
Linda HamiltonOriginal
2024-12-30 00:18:14817Durchsuche

How to Retrieve Indexed Column Information in PostgreSQL?

Informationen zu indizierten Spalten in PostgreSQL abrufen

In MySQL kann der Befehl SHOW INDEXES verwendet werden, um die Spalten abzurufen, die für eine bestimmte Person indiziert sind Tisch. In PostgreSQL gibt es jedoch kein direktes Äquivalent zu diesem Befehl.

Um diese Informationen in PostgreSQL zu erhalten, können Sie die folgende Abfrage verwenden:

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 t.relname LIKE 'test%';

Diese Abfrage verknüpft die pg_class-Tabelle ( die Tabelle pg_index (die Informationen zu Tabellen enthält), die Tabelle pg_index (die Informationen zu Indizes enthält) und die Tabelle pg_attribute (die Informationen zu Tabellenspalten enthält). Anschließend werden die Ergebnisse so gefiltert, dass nur Indizes für eine bestimmte Tabelle enthalten sind (in diesem Beispiel Tabellen, deren Namen mit „test“ beginnen).

Die Ausgabe dieser Abfrage ist eine Liste der Indexnamen und der darin enthaltenen Spalten Sie decken ab.

Um es zusammenzufassen: Während MySQL über einen dedizierten Befehl zum Abrufen indizierter Spalteninformationen verfügt, erfordert PostgreSQL eine komplexere Abfrage mit mehreren Tabellenverknüpfungen. Nichtsdestotrotz kann die bereitgestellte Abfrage die Aufgabe effektiv erledigen.

Das obige ist der detaillierte Inhalt vonWie rufe ich indizierte Spalteninformationen in PostgreSQL ab?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn