it-swarm.dev

Jak wyświetlić listę wszystkich baz danych i tabel za pomocą psql?

Próbuję nauczyć się administracji PostgreSQL i zacząłem uczyć się, jak korzystać z narzędzia wiersza polecenia psql.

Kiedy loguję się za pomocą psql --username=postgres, jak wyświetlić listę wszystkich baz danych i tabel?

Próbowałem \d, d i dS+ ale nic nie ma na liście. Utworzyłem dwie bazy danych i kilka tabel za pomocą pgAdmin III, więc wiem, że powinny być wymienione.

1243
Jonas

Proszę zwrócić uwagę na następujące polecenia:

  • \list lub \l: lista wszystkich baz danych
  • \dt: wyświetl wszystkie tabele w bieżącej bazie danych, używając search_path
  • \dt *.: wyświetl wszystkie tabele w bieżącej bazie danych bez względu na search_path

Nigdy nie zobaczysz tabel w innych bazach danych, tabele te nie są widoczne. Musisz połączyć się z właściwą bazą danych, aby zobaczyć jej tabele (i inne obiekty).

Aby przełączyć bazy danych:

\connect database_name lub \c database_name

Zobacz instrukcję o psql .

1639
Frank Heikens

Zawiera listę baz danych:

SELECT datname FROM pg_database
WHERE datistemplate = false;

Zawiera listę tabel w bieżącej bazie danych

SELECT table_schema,table_name
FROM information_schema.tables
ORDER BY table_schema,table_name;
381
RolandoMySQLDBA

W Postgresql te polecenia terminala wyświetlają listę dostępnych baz danych

[email protected]$ /bin/psql -h localhost --username=pgadmin --list

Lub polecenie brzmiało prościej:

psql -U pgadmin -l

Te polecenia drukują to na terminalu:

                                  List of databases
   Name    |  Owner   | Encoding |   Collate   |    Ctype    |   Access privileges
-----------+----------+----------+-------------+-------------+-----------------------
 kurz_prod | pgadmin  | UTF8     | en_US.UTF-8 | en_US.UTF-8 |
 pgadmin   | pgadmin  | UTF8     | en_US.UTF-8 | en_US.UTF-8 |
 postgres  | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |
 template0 | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
           |          |          |             |             | postgres=CTc/postgres
 template1 | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
           |          |          |             |             | postgres=CTc/postgres
(5 rows)

To są dostępne bazy danych.

W PSQL te polecenia wyświetlają listę dostępnych tabel

Musisz określić bazę danych, aby móc wyświetlić tabele w tej bazie danych.

[email protected]$ psql -U pgadmin -d kurz_prod

To prowadzi do terminala psql:

kurz_prod=#

Użyj polecenia \d oznacza pokaż wszystkie tabele, widoki i sekwencje

kurz_prod=# \d

To drukuje:

           List of relations
Schema |  Name   |   Type   |  Owner
--------+---------+----------+---------
public | mytable | table    | pgadmin
public | testing | sequence | pgadmin
(2 rows)

Następnie, aby wyjść z terminala psql, wpisz \q i naciśnij enter. Lub Ctrl-D robi to samo. To są tabele w tej bazie danych.

112
Eric Leschinski

\l jest także skrótem od \list. Istnieje wiele poleceń ukośnika, które można wyświetlić w psql za pomocą \?.

74
Derek Arnold

Aby uzyskać więcej informacji o bazie danych i liście tabel, możesz:

\l+, aby wyświetlić listę baz danych

                                                                    List of databases
    Name    |  Owner   | Encoding |   Collate   |    Ctype    |   Access privileges   |  Size   | Tablespace |                Description
------------+----------+----------+-------------+-------------+-----------------------+---------+------------+--------------------------------------------
 pgbench    | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |                       | 29 MB   | pg_default |
 postgres   | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |                       | 6073 kB | pg_default | default administrative connection database
 slonmaster | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |                       | 1401 MB | movespace  |
 slonslave  | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |                       | 32 MB   | pg_default |
 template0  | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +| 5785 kB | pg_default | unmodifiable empty database
            |          |          |             |             | postgres=CTc/postgres |         |            |
 template1  | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +| 5985 kB | pg_default | default template for new databases
            |          |          |             |             | postgres=CTc/postgres |         |            |
 test       | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |                       | 13 MB   | pg_default |
(7 rows)

i

\d+, aby wyświetlić listę wszystkich tabel w bieżącym schemacie ścieżka_wyszukiwania w bieżącej bazie danych.

test=# \dn+ --list schemas
                          List of schemas
  Name  |  Owner   |  Access privileges   |      Description       
--------+----------+----------------------+------------------------
 public | postgres | postgres=UC/postgres+| standard public schema
        |          | =UC/postgres         | 
schema1 | postgres | postgres=UC/postgres+| 
        |          | =UC/postgres         | 
(2 row)

test=# set search_path to schema1, public;
SET
test=# \d+
                                  List of relations
     Schema  |      Name       | Type  |    Owner     |    Size    | Description
    ---------+-----------------+-------+--------------+------------+-------------
     public  | all_units       | table | postgres     | 0 bytes    |
     public  | asset           | table | postgres     | 16 kB      |
     public  | asset_attribute | table | postgres     | 8192 bytes |
     public  | food            | table | postgres     | 48 kB      |
     public  | name_log        | table | postgres     | 8192 bytes |
     public  | outable         | table | ordinaryuser | 0 bytes    |
     public  | outable2        | table | ordinaryuser | 0 bytes    |
     public  | test            | table | postgres     | 16 kB      |
     public  | usr             | table | postgres     | 5008 kB    |
     schema1 | t1              | table | postgres     | 0 bytes    |
    (10 rows)
36
Soni Harriz

Z pg_Admin możesz po prostu uruchomić następujące operacje na bieżącej bazie danych, a uzyska wszystkie tabele dla określonego schematu:

SELECT * 
FROM information_schema.tables 
WHERE table_type = 'BASE TABLE' 
    AND table_schema = 'public' 
ORDER BY table_type, table_name

Otrzymasz listę wszystkich stałych tabel (ogólnie tych, których szukasz). Możesz uzyskać tylko nazwy tabel, jeśli zmienisz * symbol wieloznaczny do _ table_name. Publiczny table_schema jest domyślnym schematem dla większości baz danych, chyba że administrator skonfigurował nowy schemat.

33
Larry W

Możliwe, że wstawiłeś tabele do schematu, który nie znajduje się na ścieżce wyszukiwania, lub domyślny, tj. Publiczny, więc tabele nie będą wyświetlane przy użyciu\dt. Jeśli używasz schematu o nazwie powiedzmy dane, możesz to naprawić, uruchamiając,

alter database <databasename> set search_path=data, public;

Wyjdź i ponownie wprowadź psql, a teraz\dt wyświetli również tabele w danych schematu.

19
John Powell