platform-db/changesets/registry/procedures/f_get_tables_to_replicate.sql (27 lines of code) (raw):

--liquibase formatted sql /* * Copyright 2021 EPAM Systems. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * https://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ --changeset platform:f_get_tables_to_replicate splitStatements:false stripComments:false runOnChange:true CREATE OR REPLACE FUNCTION f_get_tables_to_replicate(p_publication_name TEXT) RETURNS TEXT LANGUAGE plpgsql AS $function$ BEGIN RETURN (SELECT string_agg('"'||table_name||'"', ', ') FROM ( SELECT table_name FROM information_schema.tables WHERE table_type = 'BASE TABLE' AND ( table_schema = 'registry' OR ( table_schema = 'public' and table_name like 'ddm_source%' ) ) EXCEPT SELECT tablename FROM pg_catalog.pg_publication_tables WHERE pubname = p_publication_name ) s ); END; $function$ SECURITY DEFINER SET search_path = registry, public, pg_temp;