我需要从 Postgres SQL 中删除选定的表。最好使用like
或where
子句。
就像我一样
TABLE_A
TABLE_B
TABLE_C
-
-
-
TABLE_N
我要删除
TABLE_A to TABLE_X
最佳答案
可以使用单个命令完成,速度更快 - 如果这是一项重复性任务。
如果不确定是否存在任何表,请添加IF EXISTS
。通过这种方式,我们可以节省对系统目录(information_schema.tables
或 pg_catalog.pg_tables
)的额外访问。
您可能想要添加 CASCADE
:
DO
$do$
BEGIN
-- child safety device: quote RAISE instead of EXECUTE to prime the bomb
-- EXECUTE (
RAISE NOTICE '%', (
SELECT 'DROP TABLE IF EXISTS'
|| string_agg('table_' || chr(ascii('a') + g) , ', ')
|| ' CASCADE;'
FROM generate_series(0,13) g
);
END
$do$;
生成以下形式的命令:
DROP TABLE IF EXISTS table_a, table_b, ... , table_n CASCADE;
使用 generate_series()
生成请求的表名。更多信息:
关于postgresql - 从 Postgresql 中删除选定的表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53531015/