When working with partitions, there is often a need to delete all partitions at once.
However
DROP TABLE tablename*
Does not work. (The wildcard is not respected).
Is there an elegant (read: easy to remember) way to drop multiple tables in one command with a wildcard?
Advertisement
Answer
Use a comma separated list:
DROP TABLE foo, bar, baz;
If you realy need a footgun, this one will do it’s job:
CREATE OR REPLACE FUNCTION footgun(IN _schema TEXT, IN _parttionbase TEXT) RETURNS void LANGUAGE plpgsql AS $$ DECLARE row record; BEGIN FOR row IN SELECT table_schema, table_name FROM information_schema.tables WHERE table_type = 'BASE TABLE' AND table_schema = _schema AND table_name ILIKE (_parttionbase || '%') LOOP EXECUTE 'DROP TABLE ' || quote_ident(row.table_schema) || '.' || quote_ident(row.table_name) || ' CASCADE '; RAISE INFO 'Dropped table: %', quote_ident(row.table_schema) || '.' || quote_ident(row.table_name); END LOOP; END; $$; SELECT footgun('public', 'tablename');