Was ist der beste Weg, um alle Tabellen im PostgreSQL-Informationsschema aufzulisten?
Zur Verdeutlichung: Ich arbeite mit einer leeren DB (ich habe keine eigenen Tabellen hinzugefügt), möchte aber jede Tabelle in der Struktur information_schema sehen.
Sie sollten in der Lage sein, nur select * from information_schema.tables
, um eine Liste aller von Postgres für eine bestimmte Datenbank verwalteten Tabellen abzurufen.
Sie können auch ein where table_schema = 'information_schema'
, um nur die Tabellen im Informationsschema anzuzeigen.
Um Ihre Tabellen aufzulisten, verwenden Sie:
SELECT table_name FROM information_schema.tables WHERE table_schema='public'
Es werden nur die von Ihnen erstellten Tabellen aufgelistet.
\dt information_schema.
von innerhalb von psql sollte in Ordnung sein.
Das "\ z" BEFEHL ist auch eine gute Möglichkeit, Tabellen innerhalb der interaktiven psql-Sitzung aufzulisten.
z.B.
# psql -d mcdb -U admin -p 5555
mcdb=# /z
Access privileges for database "mcdb"
Schema | Name | Type | Access privileges
--------+--------------------------------+----------+---------------------------------------
public | activities | table |
public | activities_id_seq | sequence |
public | activities_users_mapping | table |
[..]
public | v_schedules_2 | view | {admin=arwdxt/admin,viewuser=r/admin}
public | v_systems | view |
public | vapp_backups | table |
public | vm_client | table |
public | vm_datastore | table |
public | vmentity_hle_map | table |
(148 rows)
Sie können auch verwenden
select * from pg_tables where schemaname = 'information_schema'
In generellen pg * -Tabellen können Sie alles in der Datenbank sehen, ohne auf Ihre Berechtigungen beschränkt zu sein (wenn Sie natürlich Zugriff auf die Tabellen haben).
Für privates Schema 'xxx'
in postgresql:
SELECT table_name FROM information_schema.tables
WHERE table_schema = 'xxx' AND table_type = 'BASE TABLE'
Ohne table_type = 'BASE TABLE'
, werden Sie Tabellen und Ansichten auflisten
1.Geben Sie alle Tabellen und Ansichten aus information_schema.tables ein, einschließlich information_schema und pg_catalog.
select * from information_schema.tables
2.get Tabellen und Ansichten gehören bestimmte Schema
select * from information_schema.tables
where table_schema not in ('information_schema', 'pg_catalog')
3.get nur Tabellen (fast\dt)
select * from information_schema.tables
where table_schema not in ('information_schema', 'pg_catalog') and
table_type = 'BASE TABLE'
Wenn Sie eine schnelle und schmutzige Einzeiler-Abfrage wünschen:
select * from information_schema.tables
Sie können es direkt im Abfrage-Tool ausführen, ohne psql öffnen zu müssen.
(Andere Beiträge schlagen genauere information_schema-Abfragen vor, aber als Neuigkeit finde ich, dass diese einzeilige Abfrage mir hilft, die Tabelle in den Griff zu bekommen.)