wake-up-neo.com

Listen Sie alle Tabellen in postgresql information_schema auf

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.

157
littleK

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.

220
RodeoClown

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.

87
phsaires
\dt information_schema.

von innerhalb von psql sollte in Ordnung sein.

37
user80168

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)
13
Chris Shoesmith

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).

8
Timofey

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

7
germanlinux

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'
4
hzh

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.)

1
Sally Levesque