RE: Support logical replication of DDLs
От | houzj.fnst@fujitsu.com |
---|---|
Тема | RE: Support logical replication of DDLs |
Дата | |
Msg-id | OS0PR01MB571676298B814F7F5690D92994BB9@OS0PR01MB5716.jpnprd01.prod.outlook.com обсуждение исходный текст |
Ответ на | Re: Support logical replication of DDLs (Amit Kapila <amit.kapila16@gmail.com>) |
Ответы |
Re: Support logical replication of DDLs
Re: Support logical replication of DDLs |
Список | pgsql-hackers |
On Wednesday, June 29, 2022 11:07 AM Amit Kapila <amit.kapila16@gmail.com> wrote: > > On Tue, Jun 28, 2022 at 5:43 PM Amit Kapila <amit.kapila16@gmail.com> > wrote: > > > > 5. > > +static ObjTree * > > +deparse_CreateStmt(Oid objectId, Node *parsetree) > > { > > ... > > + tmp = new_objtree_VA("TABLESPACE %{tablespace}I", 0); if > > + (node->tablespacename) append_string_object(tmp, "tablespace", > > + node->tablespacename); else { append_null_object(tmp, "tablespace"); > > + append_bool_object(tmp, "present", false); } > > + append_object_object(createStmt, "tablespace", tmp); > > ... > > } > > > > Why do we need to append the objects (tablespace, with clause, etc.) > > when they are not present in the actual CREATE TABLE statement? The > > reason to ask this is that this makes the string that we want to send > > downstream much longer than the actual statement given by the user on > > the publisher. > > > > After thinking some more on this, it seems the user may want to optionally > change some of these attributes, for example, on the subscriber, it may want to > associate the table with a different tablespace. I think to address that we can > append these additional attributes optionally, say via an additional parameter > (append_all_options/append_all_attributes or something like that) in exposed > APIs like deparse_utility_command(). I agree and will research this part. And here is the new version patch set. Most of changes are in the deparser which include: support CREATE PARTITIONED TABLE support ALTER ATTACH/DETACH PARTITION support CREATE/ALTER TABLE with ACCESS METHOD support CREATE TABLE OF support CREATE/ALTER TABLE with GENERATED COLUMN support CREATE/ALTER TABLE with DENTITY COLUMN support CREATE/ALTER TABLE with COMPRESSION METHOD support ALTER COLUMN numofcol SET STATISTICS (mentioned by sawada-san [1]) support ALTER SCHEMA support CRAETE/DROP INDEX Note that, for ATTACH/DETACH PARTITION, I haven't added extra logic on subscriber to handle the case where the table on publisher is a PARTITIONED TABLE while the target table on subscriber side is NORMAL table. We will research this more and improve this later. Besides, the new version event trigger won't WAL log the DDL whose target table is a temporary table so that the problem reported by Vignesh[2] is fixed. About the recent comment from Amit[3] and Vignesh[4], I will investigate the comments and address them in next version. [1] https://www.postgresql.org/message-id/CAD21AoBVCoPPRKvU_5-%3DwEXsa92GsNJFJOcYyXzvoSEJCx5dKw%40mail.gmail.com [2] https://www.postgresql.org/message-id/CALDaNm33W35pcBE3zOpJhwnYBdBoZDpKxssemAN21NwVhJuong%40mail.gmail.com [3] https://www.postgresql.org/message-id/CAA4eK1K88SMoBq%3DDRA4XU-F3FG6qyzCjGMMKsPpcRBPRcrELrw%40mail.gmail.com [4] https://www.postgresql.org/message-id/CALDaNm3rEA_zmnDMOCT7NqK4aAffhAgooLf8rXjUN%3DYwA8ASFw%40mail.gmail.com Best regards, Hou zj
Вложения
В списке pgsql-hackers по дате отправления: