How to copy Datum

Started by Wang, Chaoyongover 13 years ago1 messagesgeneral
Jump to latest
#1Wang, Chaoyong
Chaoyong.Wang@emc.com

Hi,

I'm trying to reduce the re-computing of window aggregation. Here the
AVG function for example.

The original window aggregation's transition value(transValue) of AVG is
an ArrayType, that contains two main values(sum, count).

Now, I'm using a temporary transition value (tempTransValue), and I need
to copy tempTransValue to the original window aggregation's transition
value(transValue).

I used the function datumCopy as following:

peraggstate->transValue = datumCopy(peraggstate->tempTransValue,
peraggstate->transtypeByVal, peraggstate->transtypeLen);

But when the copied transValue is passed to the invoke function, here is
int4_avg_accum, the ArrayType returned from PG_GETARG_ARRAYTYPE_P(0) is
null.

Which means the copy action is failed.

Anybody know why? Or give me some suggestions? Thanks very much.

Best Regards

Chaoyong Wang