Re: Column Filtering in Logical Replication
От | vignesh C |
---|---|
Тема | Re: Column Filtering in Logical Replication |
Дата | |
Msg-id | CALDaNm1YoxJCs=uiyPM=tFDDc2qn0ja01nb2TCPqrjZH2jR0sQ@mail.gmail.com обсуждение исходный текст |
Ответ на | Re: Column Filtering in Logical Replication (Alvaro Herrera <alvherre@alvh.no-ip.org>) |
Ответы |
Re: Column Filtering in Logical Replication
Re: Column Filtering in Logical Replication RE: Column Filtering in Logical Replication Re: Column Filtering in Logical Replication |
Список | pgsql-hackers |
On Wed, Sep 15, 2021 at 5:20 PM Alvaro Herrera <alvherre@alvh.no-ip.org> wrote: > > On 2021-Sep-15, Amit Kapila wrote: > > > On Mon, Sep 6, 2021 at 11:21 PM Alvaro Herrera <alvherre@alvh.no-ip.org> wrote: > > > > > > I pushed the clerical part of this -- namely the addition of > > > PublicationTable node and PublicationRelInfo struct. > > > > One point to note here is that we are developing a generic grammar for > > publications where not only tables but other objects like schema, > > sequences, etc. can be specified, see [1]. So, there is some overlap > > in the grammar modifications being made by this patch and the work > > being done in that other thread. > > Oh rats. I was not aware of that thread, or indeed of the fact that > adding multiple object types to publications was being considered. > > I do see that 0002 there contains gram.y changes, but AFAICS those > changes don't allow specifying a column list for a table, so there are > some changes needed in that patch for that either way. > > I agree that it's better to move forward in unison. > > I noticed that 0002 in that other patch uses a void * pointer in > PublicationObjSpec that "could be either RangeVar or String", which > strikes me as a really bad idea. (Already discussed in some other > thread recently, maybe this one or the row filtering one.) I have extracted the parser code and attached it here, so that it will be easy to go through. We wanted to support the following syntax as in [1]: CREATE PUBLICATION pub1 FOR TABLE t1,t2,t3, ALL TABLES IN SCHEMA s1,s2, SEQUENCE seq1,seq2, ALL SEQUENCES IN SCHEMA s3,s4; Columns can be added to PublicationObjSpec data structure. The patch Generic_object_type_parser_002_table_schema_publication.patch has the changes that were used to handle the parsing. Schema and Relation both are different objects, schema is of string type and relation is of RangeVar type. While parsing, schema name is parsed in string format and relation is parsed and converted to rangevar type, these objects will be then handled accordingly during post processing. That is the reason it used void * type which could hold both RangeVar and String. Thoughts? [1] - https://www.postgresql.org/message-id/877603.1629120678%40sss.pgh.pa.us Regards, Vignesh
Вложения
В списке pgsql-hackers по дате отправления: