Commit 3ccb2c59 authored by Heikki Linnakangas's avatar Heikki Linnakangas

Extend VacAttrStats to allow typanalyze functions to store statistic values

of different types than the underlying column. The capability isn't yet
used for anything, but will be required by upcoming patch to analyze
tsvector columns.

Jan Urbanski
parent baaad233
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/commands/analyze.c,v 1.122 2008/06/08 22:00:47 alvherre Exp $ * $PostgreSQL: pgsql/src/backend/commands/analyze.c,v 1.123 2008/07/01 10:33:09 heikki Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -684,6 +684,7 @@ examine_attribute(Relation onerel, int attnum) ...@@ -684,6 +684,7 @@ examine_attribute(Relation onerel, int attnum)
Form_pg_attribute attr = onerel->rd_att->attrs[attnum - 1]; Form_pg_attribute attr = onerel->rd_att->attrs[attnum - 1];
HeapTuple typtuple; HeapTuple typtuple;
VacAttrStats *stats; VacAttrStats *stats;
int i;
bool ok; bool ok;
/* Never analyze dropped columns */ /* Never analyze dropped columns */
...@@ -711,6 +712,20 @@ examine_attribute(Relation onerel, int attnum) ...@@ -711,6 +712,20 @@ examine_attribute(Relation onerel, int attnum)
stats->anl_context = anl_context; stats->anl_context = anl_context;
stats->tupattnum = attnum; stats->tupattnum = attnum;
/*
* The fields describing the stats->stavalues[n] element types default
* to the type of the field being analyzed, but the type-specific
* typanalyze function can change them if it wants to store something
* else.
*/
for (i = 0; i < STATISTIC_NUM_SLOTS; i++)
{
stats->statypid[i] = stats->attr->atttypid;
stats->statyplen[i] = stats->attrtype->typlen;
stats->statypbyval[i] = stats->attrtype->typbyval;
stats->statypalign[i] = stats->attrtype->typalign;
}
/* /*
* Call the type-specific typanalyze function. If none is specified, use * Call the type-specific typanalyze function. If none is specified, use
* std_typanalyze(). * std_typanalyze().
...@@ -1322,10 +1337,10 @@ update_attstats(Oid relid, int natts, VacAttrStats **vacattrstats) ...@@ -1322,10 +1337,10 @@ update_attstats(Oid relid, int natts, VacAttrStats **vacattrstats)
arry = construct_array(stats->stavalues[k], arry = construct_array(stats->stavalues[k],
stats->numvalues[k], stats->numvalues[k],
stats->attr->atttypid, stats->statypid[k],
stats->attrtype->typlen, stats->statyplen[k],
stats->attrtype->typbyval, stats->statypbyval[k],
stats->attrtype->typalign); stats->statypalign[k]);
values[i++] = PointerGetDatum(arry); /* stavaluesN */ values[i++] = PointerGetDatum(arry); /* stavaluesN */
} }
else else
...@@ -1855,6 +1870,10 @@ compute_minimal_stats(VacAttrStatsP stats, ...@@ -1855,6 +1870,10 @@ compute_minimal_stats(VacAttrStatsP stats,
stats->numnumbers[0] = num_mcv; stats->numnumbers[0] = num_mcv;
stats->stavalues[0] = mcv_values; stats->stavalues[0] = mcv_values;
stats->numvalues[0] = num_mcv; stats->numvalues[0] = num_mcv;
/*
* Accept the defaults for stats->statypid and others.
* They have been set before we were called (see vacuum.h)
*/
} }
} }
else if (null_cnt > 0) else if (null_cnt > 0)
...@@ -2198,6 +2217,10 @@ compute_scalar_stats(VacAttrStatsP stats, ...@@ -2198,6 +2217,10 @@ compute_scalar_stats(VacAttrStatsP stats,
stats->numnumbers[slot_idx] = num_mcv; stats->numnumbers[slot_idx] = num_mcv;
stats->stavalues[slot_idx] = mcv_values; stats->stavalues[slot_idx] = mcv_values;
stats->numvalues[slot_idx] = num_mcv; stats->numvalues[slot_idx] = num_mcv;
/*
* Accept the defaults for stats->statypid and others.
* They have been set before we were called (see vacuum.h)
*/
slot_idx++; slot_idx++;
} }
...@@ -2282,6 +2305,10 @@ compute_scalar_stats(VacAttrStatsP stats, ...@@ -2282,6 +2305,10 @@ compute_scalar_stats(VacAttrStatsP stats,
stats->staop[slot_idx] = mystats->ltopr; stats->staop[slot_idx] = mystats->ltopr;
stats->stavalues[slot_idx] = hist_values; stats->stavalues[slot_idx] = hist_values;
stats->numvalues[slot_idx] = num_hist; stats->numvalues[slot_idx] = num_hist;
/*
* Accept the defaults for stats->statypid and others.
* They have been set before we were called (see vacuum.h)
*/
slot_idx++; slot_idx++;
} }
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $PostgreSQL: pgsql/src/include/commands/vacuum.h,v 1.78 2008/06/19 00:46:06 alvherre Exp $ * $PostgreSQL: pgsql/src/include/commands/vacuum.h,v 1.79 2008/07/01 10:33:09 heikki Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -93,6 +93,18 @@ typedef struct VacAttrStats ...@@ -93,6 +93,18 @@ typedef struct VacAttrStats
int numvalues[STATISTIC_NUM_SLOTS]; int numvalues[STATISTIC_NUM_SLOTS];
Datum *stavalues[STATISTIC_NUM_SLOTS]; Datum *stavalues[STATISTIC_NUM_SLOTS];
/*
* These fields describe the stavalues[n] element types. They will
* be initialized to be the same as the column's that's underlying the
* slot, but a custom typanalyze function might want to store an array of
* something other than the analyzed column's elements. It should then
* overwrite these fields.
*/
Oid statypid[STATISTIC_NUM_SLOTS];
int2 statyplen[STATISTIC_NUM_SLOTS];
bool statypbyval[STATISTIC_NUM_SLOTS];
char statypalign[STATISTIC_NUM_SLOTS];
/* /*
* These fields are private to the main ANALYZE code and should not be * These fields are private to the main ANALYZE code and should not be
* looked at by type-specific functions. * looked at by type-specific functions.
......
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