Postgres DROP TABLE с помощью DO DECLARE и EXECUTE - PullRequest
0 голосов
/ 29 октября 2019

Я пытаюсь удалить таблицы, возвращенные из запроса, используя EXECUTE. Вот пример:

CREATE TABLE test_a (id BIGINT);
CREATE TABLE test_b (id BIGINT);

DO
$f$
DECLARE command TEXT;
BEGIN
SELECT INTO command 'SELECT ARRAY_TO_STRING(ARRAY_AGG($$DROP TABLE $$ || table_name), $$;$$) FROM information_schema.tables WHERE table_name ILIKE $$test%$$';
EXECUTE command;
END;
$f$;

Оператор SELECT возвращает " DROP TABLE test_a; DROP TABLE test_b ", который я передаю в объявленную переменную и пытаюсь запустить с помощью EXECUTE, нобезрезультатно. Что я делаю не так?

PostgreSQL 9.5.18, скомпилированный в Visual C ++ build 1800, 64-bit

1 Ответ

3 голосов
/ 29 октября 2019

Вы сохраняете строку SELECT ARRAY_TO_STRING ... в этой переменной, а не результат инструкции SELECT.

Вы также можете упростить ARRAY_TO_STRING(ARRAY_AGG(..)) до string_agg(), и настоятельно рекомендуется использовать format() для генерации динамического SQL, чтобы правильно обрабатывать идентификаторы, которые необходимо заключать в кавычки.

Используйте следующее:

DO
$f$
DECLARE 
  command TEXT;
BEGIN

 SELECT string_agg(format('drop table %I', table_name), ';')
   INTO command
 FROM information_schema.tables 
 WHERE table_name ILIKE 'test%';

 execute command;
END;
$f$;
...