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!