Commit 62bf0fb3 authored by Tomas Vondra's avatar Tomas Vondra

Fix deserialization of pg_mcv_list values

There were multiple issues in deserialization of pg_mcv_list values.

Firstly, the data is loaded from syscache, but the deserialization was
performed after ReleaseSysCache(), at which point the data might have
already disappeared.  Fixed by moving the calls in statext_mcv_load,
and using the same NULL-handling code as existing stats.

Secondly, the deserialized representation used pointers into the
serialized representation.  But that is also unsafe, because the data
may disappear at any time.  Fixed by reworking and simplifying the
deserialization code to always copy all the data.

And thirdly, when deserializing values for types passed by value, the
code simply did memcpy(d,s,typlen) which however does not work on
bigendian machines.  Fixed by using fetch_att/store_att_byval.
parent f3afbbda
This diff is collapsed.
...@@ -107,7 +107,7 @@ typedef struct MCVList ...@@ -107,7 +107,7 @@ typedef struct MCVList
uint32 nitems; /* number of MCV items in the array */ uint32 nitems; /* number of MCV items in the array */
AttrNumber ndimensions; /* number of dimensions */ AttrNumber ndimensions; /* number of dimensions */
Oid types[STATS_MAX_DIMENSIONS]; /* OIDs of data types */ Oid types[STATS_MAX_DIMENSIONS]; /* OIDs of data types */
MCVItem **items; /* array of MCV items */ MCVItem items[FLEXIBLE_ARRAY_MEMBER]; /* array of MCV items */
} MCVList; } MCVList;
extern MVNDistinct *statext_ndistinct_load(Oid mvoid); extern MVNDistinct *statext_ndistinct_load(Oid mvoid);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment