Подтвердить что ты не робот

Как я могу узнать, что находится в табличном пространстве Postgresql?

Я создал новое табличное пространство под названием indexes, и я пытаюсь удалить старое табличное пространство indexes_old, которое использовалось для хранения некоторых таблиц и индексов. Когда я пытаюсь удалить табличное пространство, я получаю:

=> drop tablespace indexes_old;
ERROR:  tablespace "indexes_old" is not empty

Но когда я пытаюсь увидеть, что там, кажется, что в этом табличном пространстве нет таблиц:

=> select * from pg_tables where tablespace = 'indexes_old';
schemaname | tablename | tableowner | tablespace | hasindexes | hasrules | hastriggers
------------+-----------+------------+------------+------------+----------+-------------
(0 rows)

=> select * from pg_indexes where tablespace = 'indexes_old';
schemaname | tablename | indexname | tablespace | indexdef
------------+-----------+-----------+------------+----------
(0 rows)

Итак, что в этом табличном пространстве мешает мне отказаться от него?

В случае, если это имеет значение, я только что перешел с Pg 8.4 на Pg 9.0 с помощью инструмента pg_upgrade.

Табличные пространства выглядят следующим образом:

    Name     |  Owner   |    Location     | Access privileges | Description 
-------------+----------+-----------------+-------------------+-------------
 indexes     | nobody   | /data/pgindex90 |                   | 
 indexes_old | nobody   | /data/pgindex84 |                   | 

а содержимое /data/pgindex 84 включает все старые индексы 8.4, а также новый индекс 9.0, который автоматически создает pg_upgrade

# sudo ls -al /data/pgindex84/PG_9.0_201008051/11874
total 8280
drwx------ 2 postgres postgres    4096 Feb  9 14:58 .
drwx------ 3 postgres postgres    4096 Feb 11 09:28 ..
-rw------- 1 postgres postgres   40960 Feb  9 14:58 10462602
-rw------- 1 postgres postgres   40960 Feb  9 14:58 10462604
-rw------- 1 postgres postgres 4644864 Feb  9 14:58 10462614
-rw------- 1 postgres postgres 3727360 Feb  9 14:58 10462616
4b9b3361

Ответ 1

Проверьте pg_class, чтобы узнать, где находится:

SELECT 
  c.relname, 
  t.spcname 
FROM 
  pg_class c 
    JOIN pg_tablespace t ON c.reltablespace = t.oid 
WHERE 
  t.spcname = 'indexes_old';

Ответ 2

В PostgreSQL табличное пространство может использоваться любой базой данных PostgreSQL. (Пока запрашивающий пользователь имеет достаточные привилегии, то есть.) Я думаю, что этот запрос

SELECT spcname, spclocation FROM pg_tablespace;

покажет вам каталог, который index_old использует в файловой системе в версии PostgreSQL до 9.1. Прогуляйтесь туда, чтобы увидеть, действительно ли на вашем пути что-то реальное. Я был бы очень осторожен в попытке удалить что-либо там, кроме использования интерфейса PostgreSQL.

В 9.2+ попробуйте

select spcname, pg_tablespace_location(oid) from pg_tablespace;

Ответ 3

В PG 10 и, возможно, немного раньше, это, похоже, изменилось:

SELECT tablename from pg_tables WHERE tablespace = ‘foo’;

Ответ 4

Мы говорим о интерфейсе PgSQL?

Список схем (табличных пространств):

\dn

Перечислите все таблицы внутри схемы (табличное пространство) следующим образом:

\dn <table_space>.*

Использование

\?

для дополнительных параметров