Source: postgres_stored_procedures/sp_merge_tables.sql at main · thevillagers/postgres_stored_procedures
/*
Merges all tables matching a regex by calling vre_funcs.insert() on all matches
USAGE:
CALL vre_funcs.merge(
table_regex:='^public\.test',
output_table:='public.test_tables_merged'
);
*/
DROP PROCEDURE IF EXISTS vre_funcs.merge;
CREATE PROCEDURE vre_funcs.merge(
table_regex TEXT, -- regular expression of tables to merge
output_table TEXT, -- output table to merge tables into
use_cstore BOOLEAN DEFAULT TRUE, -- flag indicating whether or not output should be cstore
select_col_regex TEXT DEFAULT NULL, -- regular expression of columns you want to include in the merged output
query_suffix TEXT DEFAULT NULL -- suffix for filtering which rows get pulled, if relevant. E.g. query_suffix:=$str$WHERE column='value'$str$
)
AS $$
DECLARE
matching_tables_arr TEXT[];
loop_table TEXT;
v_state TEXT ;
v_msg TEXT ;
v_detail TEXT ;
v_hint TEXT ;
v_context TEXT ;
full_error_msg TEXT ;
BEGIN
CALL vre_funcs.create_empty_table(table_name:=output_table, use_cstore:=use_cstore, drop_existing:=TRUE);
SELECT
ARRAY_AGG(QUOTE_IDENT(table_schema)||'.'||QUOTE_IDENT(table_name))
FROM
information_schema.tables
WHERE
table_schema||'.'||table_name ~ table_regex
INTO
matching_tables_arr
;
FOREACH loop_table IN ARRAY matching_tables_arr LOOP
CALL vre_funcs.insert(
insert_from := loop_table,
insert_into := output_table,
add_cols := TRUE,
create_into_table := FALSE,
select_col_regex := select_col_regex,
query_suffix := query_suffix
);
END LOOP;
EXCEPTION WHEN OTHERS THEN
GET STACKED DIAGNOSTICS
v_state = RETURNED_SQLSTATE,
v_msg = MESSAGE_TEXT,
v_detail = PG_EXCEPTION_DETAIL,
v_hint = PG_EXCEPTION_HINT,
v_context = PG_EXCEPTION_CONTEXT
;
full_error_msg := FORMAT($str$
state: %1$s
message: %2$s
detail: %3$s
hint: %4$s
context: %5$s
$str$, v_state, v_msg, v_detail, v_hint, v_context);
RAISE EXCEPTION USING MESSAGE = full_error_msg;
END ; $$
LANGUAGE 'plpgsql';
Backlinks:
list from [[SQL - PostgreSQL Stored Procedure - Merge Tables]] AND -"Changelog"