Em ter., 15 de nov. de 2022 às 04:02, Michael Paquier <mich...@paquier.xyz>
escreveu:

> On Tue, Nov 15, 2022 at 09:57:26AM +0900, Michael Paquier wrote:
> > Anyway, multi-inserts are going to be solution better than
> > CatalogTupleInsertWithInfo() in some cases, because we would just
> > generate one WAL record of N inserts rather than N records with one
> > INSERT each.
>
> Something that you did not consider in the initial patch is that we
> may finish by opening catalog indexes even in cases where this would
> not have happened on HEAD, as we may finish by doing nothing when
> copying the stats or updating them during an analyze, and that's not
> fine IMO.  However it is easy enough to minimize the cost: just do a
> CatalogOpenIndexes() when absolutely required, and close things only
> if the indexes have been opened.
>
I find it very difficult not to have some tuple to be updated,
once inside CopyStatistics and the branch cost can get in the way,
but I don't object with your solution.


>
> Then, there are the cases where it is worth switching to a
> multi-insert logic as these are going to manipulate more than 2
> entries all the time: enum list addition and two code paths of
> tsearchcmds.c (where up to 16 entries can be lined up).  This is a
> case-by-case analysis.  For example, in the case of the enums, the
> number of elements is known in advance so it is possible to know the
> number of slots that would be used and initialize them.  But that's
> not something you would do for the first tsearch bits where the data
> is built upon a scan so the slot init should be delayed.  The second
> tsearch one can use a predictible approach, like the enums based on
> the number of known elements to insert.
>
Makes sense.


>
> So I've given a try at all that, and finished with the attached.  This
> patch finishes with a list of bullet points, so this had better be
> split into different commits, I guess.
> Thoughts?
>
Missed AddRoleMems?
Could you continue with CatalogTupleInsertWithInfo, what do you think?

regards,
Ranier Vilela

Reply via email to