Hi,
I took a closer look at this, planning to way to fix this, but I think
it's actually a bit worse than reported - both in impact and ways how to
fix that.
The problem is it's not really specific to DEFAULT values. The exact
same issue exists whenever the insert uses the expressions directly.
That is, if you do this:
insert into grem1 (a) values (counter()), (counter()),
(counter()), (counter()),
(counter());
it will misbehave in exactly the same way as with the default values. Of
course, this also means that my original idea to disable batching if the
foreign table has (volatile) expression in the DEFAULT value won't fly.
This can happen whenever the to-be-inserted rows have any expressions.
But those expressions are evaluated *outside* ModifyTable - in the nodes
that produce the rows. In the above example it's ValueScan. But it could
be any other node. For example:
insert into grem1 (a) select counter() from generate_series(1,5);
does that in a subquery. But AFAICS it could be any other node.
Ideally we'd simply set batch_size=1 for those cases, but at this point
I have no idea how to check this from ModifyTable :-(
In retrospect the issue is pretty obvious, yet I haven't thought about
this while working on the batching. This is embarrassing.
regards
--
Tomas Vondra