Yanıtlar:
select * from information_schema.tables
Belirli bir veritabanı için Postgres tarafından yönetilen her tablonun bir listesini almak için çalışabilmeniz gerekir.
Ayrıca where table_schema = 'information_schema'
yalnızca bilgi şemasındaki tabloları görmek için a ekleyebilirsiniz .
Tablolarınızı listelemek için şunları kullanın:
SELECT table_name FROM information_schema.tables WHERE table_schema='public'
Yalnızca oluşturduğunuz tabloları listeler.
\dt information_schema.
psql içinden, iyi olmalı.
"\ Z" KOMUTANLIĞI da liste tabloları zaman interaktif psql'in oturum içinde iyi bir yoldur.
Örneğin.
# 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)
'xxx'
Postgresql'deki özel şema için:
SELECT table_name FROM information_schema.tables
WHERE table_schema = 'xxx' AND table_type = 'BASE TABLE'
Olmadan table_type = 'BASE TABLE'
tabloları ve görünümleri listeleyeceksiniz
1. information_schema.tables adresindeki tüm tabloları ve görünümleri alın, information_schema ve pg_catalog tablolarını ekleyin.
select * from information_schema.tables
2. tabloları ve görünümleri belirli şemaya aittir
select * from information_schema.tables
where table_schema not in ('information_schema', 'pg_catalog')
3. sadece tabloları alın (neredeyse \ dt)
select * from information_schema.tables
where table_schema not in ('information_schema', 'pg_catalog') and
table_type = 'BASE TABLE'
where table_schema not in ('information_schema', 'pg_catalog')
ne için?
Hızlı ve kirli bir satırlık sorgu istiyorsanız:
select * from information_schema.tables
Psql'yi açmak zorunda kalmadan doğrudan Sorgu aracında çalıştırabilirsiniz.
(Diğer yayınlar güzel daha spesifik information_schema sorguları önermek ama bir newby olarak, bu tek satırlı sorgu tablo ile kavramak için yardımcı olur buluyorum)