On Tue, Sep 17, 2024 at 7:02 AM Masahiko Sawada <sawada.m...@gmail.com> wrote: > > On Wed, Sep 11, 2024 at 10:30 PM Peter Smith <smithpb2...@gmail.com> wrote: > > > > Because this feature is now being implemented as a PUBLICATION option, > > there is another scenario that might need consideration; I am thinking > > about where the same table is published by multiple PUBLICATIONS (with > > different option settings) that are subscribed by a single > > SUBSCRIPTION. > > > > e.g.1 > > ----- > > CREATE PUBLICATION pub1 FOR TABLE t1 WITH (publish_generated_columns = > > true); > > CREATE PUBLICATION pub2 FOR TABLE t1 WITH (publish_generated_columns = > > false); > > CREATE SUBSCRIPTION sub ... PUBLICATIONS pub1,pub2; > > ----- > > > > e.g.2 > > ----- > > CREATE PUBLICATION pub1 FOR ALL TABLES WITH (publish_generated_columns = > > true); > > CREATE PUBLICATION pub2 FOR TABLE t1 WITH (publish_generated_columns = > > false); > > CREATE SUBSCRIPTION sub ... PUBLICATIONS pub1,pub2; > > ----- > > > > Do you know if this case is supported? If yes, then which publication > > option value wins? > > I would expect these option values are processed with OR. That is, we > publish changes of the generated columns if at least one publication > sets publish_generated_columns to true. It seems to me that we treat > multiple row filters in the same way. >
I thought that the option "publish_generated_columns" is more related to "column lists" than "row filters". Let's say table 't1' has columns 'a', 'b', 'c', 'gen1', 'gen2'. Then: PUBLICATION pub1 FOR TABLE t1 WITH (publish_generated_columns = true); is equivalent to PUBLICATION pub1 FOR TABLE t1(a,b,c,gen1,gen2); And PUBLICATION pub2 FOR TABLE t1 WITH (publish_generated_columns = false); is equivalent to PUBLICATION pub2 FOR TABLE t1(a,b,c); So, I would expect this to fail because the SUBSCRIPTION docs say "Subscriptions having several publications in which the same table has been published with different column lists are not supported." ~~ Here's another example: PUBLICATION pub3 FOR TABLE t1(a,b); PUBLICATION pub4 FOR TABLE t1(c); Won't it be strange (e.g. difficult to explain) why pub1 and pub2 table column lists are allowed to be combined in one subscription, but pub3 and pub4 in one subscription are not supported due to the different column lists? > > > > The CREATE SUBSCRIPTION docs [1] only says "Subscriptions having > > several publications in which the same table has been published with > > different column lists are not supported." > > > > Perhaps the user is supposed to deduce that the example above would > > work OK if table 't1' has no generated cols. OTOH, if it did have > > generated cols then the PUBLICATION column lists must be different and > > therefore it is "not supported" (??). > > With the patch, how should this feature work when users specify a > generated column to the column list and set publish_generated_column = > false, in the first place? raise an error (as we do today)? or always > send NULL? For this scenario, I suggested (see [1] #3) that the code could give a WARNING. As I wrote up-thread: This combination doesn't seem like something a user would do intentionally, so just silently ignoring it (which the current patch does) is likely going to give someone unexpected results/grief. ====== [1] https://www.postgresql.org/message-id/CAHut%2BPuaitgE4tu3nfaR%3DPCQEKjB%3DmpDtZ1aWkbwb%3DJZE8YvqQ%40mail.gmail.com Kind Regards, Peter Smith Fujitsu Australia