PostGIS  3.7.0dev-r@@SVN_REVISION@@

◆ _postgis_gserialized_stats()

Datum _postgis_gserialized_stats ( PG_FUNCTION_ARGS  )

Definition at line 2066 of file gserialized_estimate.c.

2067 {
2068  Oid table_oid = PG_GETARG_OID(0);
2069  text *att_text = PG_GETARG_TEXT_P(1);
2070  ND_STATS *nd_stats;
2071  char *str;
2072  text *json;
2073  int mode = 2; /* default to 2D mode */
2074  bool only_parent = false; /* default to whole tree stats */
2075 
2076  /* Check if we've been asked to not use 2d mode */
2077  if ( ! PG_ARGISNULL(2) )
2078  mode = text_p_get_mode(PG_GETARG_TEXT_P(2));
2079 
2080  /* Retrieve the stats object */
2081  nd_stats = pg_get_nd_stats_by_name(table_oid, att_text, mode, only_parent);
2082  if ( ! nd_stats )
2083  elog(ERROR, "stats for \"%s.%s\" do not exist", get_rel_name(table_oid), text_to_cstring(att_text));
2084 
2085  /* Convert to JSON */
2086  elog(DEBUG1, "stats grid:\n%s", nd_stats_to_grid(nd_stats));
2087  str = nd_stats_to_json(nd_stats);
2088  json = cstring_to_text(str);
2089  pfree(str);
2090  pfree(nd_stats);
2091 
2092  PG_RETURN_TEXT_P(json);
2093 }
static ND_STATS * pg_get_nd_stats_by_name(const Oid table_oid, const text *att_text, int mode, bool only_parent)
Pull the stats object from the PgSQL system catalogs.
static char * nd_stats_to_json(const ND_STATS *nd_stats)
Convert an ND_STATS to a JSON representation for external use.
static char * nd_stats_to_grid(const ND_STATS *stats)
Create a printable view of the ND_STATS histogram.
static int text_p_get_mode(const text *txt)
Utility function to see if the first letter of the mode argument is 'N'.
#define str(s)
N-dimensional statistics structure.

References nd_stats_to_grid(), nd_stats_to_json(), pg_get_nd_stats_by_name(), str, and text_p_get_mode().

Here is the call graph for this function: