Câu trả lời:
Bạn có thể chỉ cần chạy select * from information_schema.tables
để có được danh sách mỗi bảng đang được Postgres quản lý cho một cơ sở dữ liệu cụ thể.
Bạn cũng có thể thêm một where table_schema = 'information_schema'
để chỉ xem các bảng trong lược đồ thông tin.
Để liệt kê các bảng của bạn, hãy sử dụng:
SELECT table_name FROM information_schema.tables WHERE table_schema='public'
Nó sẽ chỉ liệt kê các bảng mà bạn tạo ra.
\dt information_schema.
từ trong psql, sẽ ổn thôi.
Các "\ z" COMMAND cũng là một cách tốt để bảng danh sách khi bên trong phiên psql tương tác.
ví dụ.
# 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)
Đối với lược đồ riêng 'xxx'
trong postgresql:
SELECT table_name FROM information_schema.tables
WHERE table_schema = 'xxx' AND table_type = 'BASE TABLE'
Không có table_type = 'BASE TABLE'
, bạn sẽ liệt kê các bảng và khung nhìn
1. quên tất cả các bảng và chế độ xem từ information_schema.tables, bao gồm các bảng của information_schema và pg_catalog.
select * from information_schema.tables
2.get bảng và khung nhìn thuộc về lược đồ nhất định
select * from information_schema.tables
where table_schema not in ('information_schema', 'pg_catalog')
3. chỉ quên các bảng (gần như \ 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')
thì để làm gì?
Nếu bạn muốn một truy vấn một lớp nhanh chóng và bẩn:
select * from information_schema.tables
Bạn có thể chạy nó trực tiếp trong công cụ Truy vấn mà không cần phải mở psql.
(Các bài đăng khác đề xuất các truy vấn information_schema cụ thể hơn nhưng với tư cách là một người mới, tôi tìm thấy truy vấn một lớp này giúp tôi nắm bắt được bảng)