On Mon, Nov 14, 2022 at 0:56 AM vignesh C <vignes...@gmail.com> wrote:
> >
> > Attach new patches.
> 

Thanks for your comments.

> Here we are having tables list to store the relids and table_infos
> list which stores pubid along with relid. Here tables list acts as a
> temporary list to get filter_partitions and then delete the
> published_rel from table_infos. Will it be possible to directly
> operate on table_infos list and remove the temporary tables list used.
> We might have to implement comparator, deduplication functions and
> change filter_partitions function to work directly on published_rel
> type list.
> +                       /
> +                        * Record the published table and the
> corresponding publication so
> +                        * that we can get row filters and column list later.
> +                        *
> +                        * When a table is published by multiple
> publications, to obtain
> +                        * all row filters and column list, the
> structure related to this
> +                        * table will be recorded multiple times.
> +                        */
> +                       foreach(lc, pub_elem_tables)
> +                       {
> +                               published_rel *table_info =
> (published_rel *) malloc(sizeof(published_rel));
> +
> +                               table_info->relid = lfirst_oid(lc);
> +                               table_info->pubid = pub_elem->oid;
> +                               table_infos = lappend(table_infos, 
> table_info);
> +                       }
> +
> +                       tables = list_concat(tables, pub_elem_tables);
> 
> Thoughts?

I think we could only deduplicate published tables per publication to get all
row filters and column lists for each published table later.
I removed the temporary list 'tables' and modified the API of the function
filter_partitions to handle published_rel type list.

Attach the new patch set.

Regards,
Wang wei

Attachment: HEAD_v15-0001-Fix-data-replicated-twice-when-specifying-publis.patch
Description: HEAD_v15-0001-Fix-data-replicated-twice-when-specifying-publis.patch

Attachment: HEAD_v15-0002-Add-clarification-for-the-behaviour-of-the-publi.patch
Description: HEAD_v15-0002-Add-clarification-for-the-behaviour-of-the-publi.patch

Attachment: REL14_v15-0001-Fix-data-replicated-twice-when-specifying-publis_patch
Description: REL14_v15-0001-Fix-data-replicated-twice-when-specifying-publis_patch

Attachment: REL15_v15-0001-Fix-data-replicated-twice-when-specifying-publis_patch
Description: REL15_v15-0001-Fix-data-replicated-twice-when-specifying-publis_patch

Reply via email to