mirror of
https://github.com/postgres/postgres.git
synced 2025-07-08 11:42:09 +03:00
Take pg_attribute out of VacAttrStats
The VacAttrStats structure contained the whole Form_pg_attribute for a column, but it actually only needs attstattarget from there. So remove the Form_pg_attribute field and make a separate field for attstattarget. This simplifies some code for extended statistics that doesn't deal with a column but an expression, which had to fake up pg_attribute rows to satisfy internal APIs. Also, we can remove some comments that essentially said "don't look at pg_attribute directly". Reviewed-by: Tomas Vondra <tomas.vondra@enterprisedb.com> Discussion: https://www.postgresql.org/message-id/flat/d6069765-5971-04d3-c10d-e4f7b2e9c459%40eisentraut.org
This commit is contained in:
@ -572,7 +572,7 @@ do_analyze_rel(Relation onerel, VacuumParams *params,
|
||||
* If the appropriate flavor of the n_distinct option is
|
||||
* specified, override with the corresponding value.
|
||||
*/
|
||||
aopt = get_attribute_options(onerel->rd_id, stats->attr->attnum);
|
||||
aopt = get_attribute_options(onerel->rd_id, stats->tupattnum);
|
||||
if (aopt != NULL)
|
||||
{
|
||||
float8 n_distinct;
|
||||
@ -927,7 +927,7 @@ compute_index_stats(Relation onerel, double totalrows,
|
||||
for (i = 0; i < attr_cnt; i++)
|
||||
{
|
||||
VacAttrStats *stats = thisdata->vacattrstats[i];
|
||||
int attnum = stats->attr->attnum;
|
||||
int attnum = stats->tupattnum;
|
||||
|
||||
if (isnull[attnum - 1])
|
||||
{
|
||||
@ -1014,12 +1014,10 @@ examine_attribute(Relation onerel, int attnum, Node *index_expr)
|
||||
return NULL;
|
||||
|
||||
/*
|
||||
* Create the VacAttrStats struct. Note that we only have a copy of the
|
||||
* fixed fields of the pg_attribute tuple.
|
||||
* Create the VacAttrStats struct.
|
||||
*/
|
||||
stats = (VacAttrStats *) palloc0(sizeof(VacAttrStats));
|
||||
stats->attr = (Form_pg_attribute) palloc(ATTRIBUTE_FIXED_PART_SIZE);
|
||||
memcpy(stats->attr, attr, ATTRIBUTE_FIXED_PART_SIZE);
|
||||
stats->attstattarget = attr->attstattarget;
|
||||
|
||||
/*
|
||||
* When analyzing an expression index, believe the expression tree's type
|
||||
@ -1086,7 +1084,6 @@ examine_attribute(Relation onerel, int attnum, Node *index_expr)
|
||||
if (!ok || stats->compute_stats == NULL || stats->minrows <= 0)
|
||||
{
|
||||
heap_freetuple(typtuple);
|
||||
pfree(stats->attr);
|
||||
pfree(stats);
|
||||
return NULL;
|
||||
}
|
||||
@ -1659,7 +1656,7 @@ update_attstats(Oid relid, bool inh, int natts, VacAttrStats **vacattrstats)
|
||||
}
|
||||
|
||||
values[Anum_pg_statistic_starelid - 1] = ObjectIdGetDatum(relid);
|
||||
values[Anum_pg_statistic_staattnum - 1] = Int16GetDatum(stats->attr->attnum);
|
||||
values[Anum_pg_statistic_staattnum - 1] = Int16GetDatum(stats->tupattnum);
|
||||
values[Anum_pg_statistic_stainherit - 1] = BoolGetDatum(inh);
|
||||
values[Anum_pg_statistic_stanullfrac - 1] = Float4GetDatum(stats->stanullfrac);
|
||||
values[Anum_pg_statistic_stawidth - 1] = Int32GetDatum(stats->stawidth);
|
||||
@ -1725,7 +1722,7 @@ update_attstats(Oid relid, bool inh, int natts, VacAttrStats **vacattrstats)
|
||||
/* Is there already a pg_statistic tuple for this attribute? */
|
||||
oldtup = SearchSysCache3(STATRELATTINH,
|
||||
ObjectIdGetDatum(relid),
|
||||
Int16GetDatum(stats->attr->attnum),
|
||||
Int16GetDatum(stats->tupattnum),
|
||||
BoolGetDatum(inh));
|
||||
|
||||
/* Open index information when we know we need it */
|
||||
@ -1860,15 +1857,13 @@ static int analyze_mcv_list(int *mcv_counts,
|
||||
bool
|
||||
std_typanalyze(VacAttrStats *stats)
|
||||
{
|
||||
Form_pg_attribute attr = stats->attr;
|
||||
Oid ltopr;
|
||||
Oid eqopr;
|
||||
StdAnalyzeData *mystats;
|
||||
|
||||
/* If the attstattarget column is negative, use the default value */
|
||||
/* NB: it is okay to scribble on stats->attr since it's a copy */
|
||||
if (attr->attstattarget < 0)
|
||||
attr->attstattarget = default_statistics_target;
|
||||
if (stats->attstattarget < 0)
|
||||
stats->attstattarget = default_statistics_target;
|
||||
|
||||
/* Look for default "<" and "=" operators for column's type */
|
||||
get_sort_group_operators(stats->attrtypid,
|
||||
@ -1909,21 +1904,21 @@ std_typanalyze(VacAttrStats *stats)
|
||||
* know it at this point.
|
||||
*--------------------
|
||||
*/
|
||||
stats->minrows = 300 * attr->attstattarget;
|
||||
stats->minrows = 300 * stats->attstattarget;
|
||||
}
|
||||
else if (OidIsValid(eqopr))
|
||||
{
|
||||
/* We can still recognize distinct values */
|
||||
stats->compute_stats = compute_distinct_stats;
|
||||
/* Might as well use the same minrows as above */
|
||||
stats->minrows = 300 * attr->attstattarget;
|
||||
stats->minrows = 300 * stats->attstattarget;
|
||||
}
|
||||
else
|
||||
{
|
||||
/* Can't do much but the trivial stuff */
|
||||
stats->compute_stats = compute_trivial_stats;
|
||||
/* Might as well use the same minrows as above */
|
||||
stats->minrows = 300 * attr->attstattarget;
|
||||
stats->minrows = 300 * stats->attstattarget;
|
||||
}
|
||||
|
||||
return true;
|
||||
@ -2051,7 +2046,7 @@ compute_distinct_stats(VacAttrStatsP stats,
|
||||
TrackItem *track;
|
||||
int track_cnt,
|
||||
track_max;
|
||||
int num_mcv = stats->attr->attstattarget;
|
||||
int num_mcv = stats->attstattarget;
|
||||
StdAnalyzeData *mystats = (StdAnalyzeData *) stats->extra_data;
|
||||
|
||||
/*
|
||||
@ -2392,8 +2387,8 @@ compute_scalar_stats(VacAttrStatsP stats,
|
||||
int *tupnoLink;
|
||||
ScalarMCVItem *track;
|
||||
int track_cnt = 0;
|
||||
int num_mcv = stats->attr->attstattarget;
|
||||
int num_bins = stats->attr->attstattarget;
|
||||
int num_mcv = stats->attstattarget;
|
||||
int num_bins = stats->attstattarget;
|
||||
StdAnalyzeData *mystats = (StdAnalyzeData *) stats->extra_data;
|
||||
|
||||
values = (ScalarItem *) palloc(samplerows * sizeof(ScalarItem));
|
||||
|
Reference in New Issue
Block a user