Re: Make COPY format extendable: Extract COPY TO format implementations - Mailing list pgsql-hackers

From Sutou Kouhei
Subject Re: Make COPY format extendable: Extract COPY TO format implementations
Date
Msg-id 20250910.114058.944005985178219874.kou@clear-code.com
Whole thread Raw
In response to Re: Make COPY format extendable: Extract COPY TO format implementations  (Masahiko Sawada <sawada.mshk@gmail.com>)
Responses Re: Make COPY format extendable: Extract COPY TO format implementations
List pgsql-hackers
Hi,

In <CAD21AoCidyfKcpf9-f2Np8kWgkM09c4TjnS1h1hcO_-CCbjeqw@mail.gmail.com>
  "Re: Make COPY format extendable: Extract COPY TO format implementations" on Tue, 9 Sep 2025 13:15:43 -0700,
  Masahiko Sawada <sawada.mshk@gmail.com> wrote:

>> I don't object your approach but we need a good way to
>> measure performance. If we use this approach, we can omit it
>> for now and we can revisit your approach later without
>> breaking compatibility. How about using this approach if we
>> can't find a good way to measure performance?
> 
> I think it would be better to hear more opinions about this idea and
> then make a decision, rather than basing our decision on whether or
> not we can measure its performance, so we can be more confident in the
> idea we have chosen. While this idea has the above downside, it could
> make sense because we always allocate the entire CopyFrom/ToStateData
> even today in spite of some fields being not used at all in binary
> format and it requires less implementation costs to hide the
> for-core-only fields. On the other hand, another possible idea is that
> we have three different structs for categories 1 (core-only), 2 (core
> and extensions), and 3 (extension-only), and expose only 2 that has a
> void pointer to 3. The core can allocate the memory for 1 that embeds
> 2 at the beginning of the fields. While this design looks cleaner and
> we can minimize overheads due to indirect references, it would require
> more implementation costs. Which method we choose, I think we need
> performance measurements in several scenarios to check if performance
> regressions don't happen unexpectedly.

OK. So the next step is collecting more opinions, right?

Could you add key people in this area to Cc to hear their
opinions? I'm not familiar with key people in the PostgreSQL
community...


Thanks,
-- 
kou



pgsql-hackers by date:

Previous
From: "Zhijie Hou (Fujitsu)"
Date:
Subject: RE: Add support for specifying tables in pg_createsubscriber.
Next
From: "Jonathan S. Katz"
Date:
Subject: PostgreSQL 18 GA press release draft