Commit 93bbeec6 authored by Alvaro Herrera's avatar Alvaro Herrera

extstats: change output functions to emit valid JSON

Manipulating extended statistics is more convenient as JSON than the
current ad-hoc format, so let's change before it's too late.

Discussion: https://postgr.es/m/20170420193828.k3fliiock5hdnehn@alvherre.pgsql
parent e9500240
...@@ -1139,8 +1139,8 @@ SELECT stxname, stxkeys, stxdependencies ...@@ -1139,8 +1139,8 @@ SELECT stxname, stxkeys, stxdependencies
FROM pg_statistic_ext FROM pg_statistic_ext
WHERE stxname = 'stts'; WHERE stxname = 'stts';
stxname | stxkeys | stxdependencies stxname | stxkeys | stxdependencies
---------+---------+-------------------------------------------- ---------+---------+------------------------------------------
stts | 1 5 | [{1 => 5 : 1.000000}, {5 => 1 : 0.423130}] stts | 1 5 | {"1 => 5": 1.000000, "5 => 1": 0.423130}
(1 row) (1 row)
</programlisting> </programlisting>
where it can be seen that column 1 (a zip code) fully determines column where it can be seen that column 1 (a zip code) fully determines column
...@@ -1225,10 +1225,9 @@ ANALYZE zipcodes; ...@@ -1225,10 +1225,9 @@ ANALYZE zipcodes;
SELECT stxkeys AS k, stxndistinct AS nd SELECT stxkeys AS k, stxndistinct AS nd
FROM pg_statistic_ext FROM pg_statistic_ext
WHERE stxname = 'stts2'; WHERE stxname = 'stts2';
-[ RECORD 1 ]--------------------------------------------- -[ RECORD 1 ]--------------------------------------------------------
k | 1 2 5 k | 1 2 5
nd | [{(b 1 2), 33178.000000}, {(b 1 5), 33178.000000}, nd | {"1, 2": 33178, "1, 5": 33178, "2, 5": 27435, "1, 2, 5": 33178}
{(b 2 5), 27435.000000}, {(b 1 2 5), 33178.000000}]
(1 row) (1 row)
</programlisting> </programlisting>
which indicates that there are three combinations of columns that which indicates that there are three combinations of columns that
......
...@@ -624,7 +624,7 @@ dependency_is_fully_matched(MVDependency * dependency, Bitmapset *attnums) ...@@ -624,7 +624,7 @@ dependency_is_fully_matched(MVDependency * dependency, Bitmapset *attnums)
* check that the attnum matches is implied by the functional dependency * check that the attnum matches is implied by the functional dependency
*/ */
static bool static bool
dependency_implies_attribute(MVDependency * dependency, AttrNumber attnum) dependency_implies_attribute(MVDependency *dependency, AttrNumber attnum)
{ {
if (attnum == dependency->attributes[dependency->nattributes - 1]) if (attnum == dependency->attributes[dependency->nattributes - 1])
return true; return true;
...@@ -641,11 +641,6 @@ staext_dependencies_load(Oid mvoid) ...@@ -641,11 +641,6 @@ staext_dependencies_load(Oid mvoid)
{ {
bool isnull; bool isnull;
Datum deps; Datum deps;
/*
* Prepare to scan pg_statistic_ext for entries having indrelid = this
* rel.
*/
HeapTuple htup = SearchSysCache1(STATEXTOID, ObjectIdGetDatum(mvoid)); HeapTuple htup = SearchSysCache1(STATEXTOID, ObjectIdGetDatum(mvoid));
if (!HeapTupleIsValid(htup)) if (!HeapTupleIsValid(htup))
...@@ -653,7 +648,6 @@ staext_dependencies_load(Oid mvoid) ...@@ -653,7 +648,6 @@ staext_dependencies_load(Oid mvoid)
deps = SysCacheGetAttr(STATEXTOID, htup, deps = SysCacheGetAttr(STATEXTOID, htup,
Anum_pg_statistic_ext_stxdependencies, &isnull); Anum_pg_statistic_ext_stxdependencies, &isnull);
Assert(!isnull); Assert(!isnull);
ReleaseSysCache(htup); ReleaseSysCache(htup);
...@@ -687,16 +681,14 @@ pg_dependencies_in(PG_FUNCTION_ARGS) ...@@ -687,16 +681,14 @@ pg_dependencies_in(PG_FUNCTION_ARGS)
Datum Datum
pg_dependencies_out(PG_FUNCTION_ARGS) pg_dependencies_out(PG_FUNCTION_ARGS)
{ {
bytea *data = PG_GETARG_BYTEA_PP(0);
MVDependencies *dependencies = statext_dependencies_deserialize(data);
int i, int i,
j; j;
StringInfoData str; StringInfoData str;
bytea *data = PG_GETARG_BYTEA_PP(0);
MVDependencies *dependencies = statext_dependencies_deserialize(data);
initStringInfo(&str); initStringInfo(&str);
appendStringInfoChar(&str, '['); appendStringInfoChar(&str, '{');
for (i = 0; i < dependencies->ndeps; i++) for (i = 0; i < dependencies->ndeps; i++)
{ {
...@@ -705,7 +697,7 @@ pg_dependencies_out(PG_FUNCTION_ARGS) ...@@ -705,7 +697,7 @@ pg_dependencies_out(PG_FUNCTION_ARGS)
if (i > 0) if (i > 0)
appendStringInfoString(&str, ", "); appendStringInfoString(&str, ", ");
appendStringInfoChar(&str, '{'); appendStringInfoChar(&str, '"');
for (j = 0; j < dependency->nattributes; j++) for (j = 0; j < dependency->nattributes; j++)
{ {
if (j == dependency->nattributes - 1) if (j == dependency->nattributes - 1)
...@@ -715,11 +707,10 @@ pg_dependencies_out(PG_FUNCTION_ARGS) ...@@ -715,11 +707,10 @@ pg_dependencies_out(PG_FUNCTION_ARGS)
appendStringInfo(&str, "%d", dependency->attributes[j]); appendStringInfo(&str, "%d", dependency->attributes[j]);
} }
appendStringInfo(&str, " : %f", dependency->degree); appendStringInfo(&str, "\": %f", dependency->degree);
appendStringInfoChar(&str, '}');
} }
appendStringInfoChar(&str, ']'); appendStringInfoChar(&str, '}');
PG_RETURN_CSTRING(str.data); PG_RETURN_CSTRING(str.data);
} }
......
...@@ -354,21 +354,26 @@ pg_ndistinct_out(PG_FUNCTION_ARGS) ...@@ -354,21 +354,26 @@ pg_ndistinct_out(PG_FUNCTION_ARGS)
StringInfoData str; StringInfoData str;
initStringInfo(&str); initStringInfo(&str);
appendStringInfoChar(&str, '['); appendStringInfoChar(&str, '{');
for (i = 0; i < ndist->nitems; i++) for (i = 0; i < ndist->nitems; i++)
{ {
MVNDistinctItem item = ndist->items[i]; MVNDistinctItem item = ndist->items[i];
int x = -1;
bool first = true;
if (i > 0) if (i > 0)
appendStringInfoString(&str, ", "); appendStringInfoString(&str, ", ");
appendStringInfoChar(&str, '{'); while ((x = bms_next_member(item.attrs, x)) >= 0)
outBitmapset(&str, item.attrs); {
appendStringInfo(&str, ", %f}", item.ndistinct); appendStringInfo(&str, "%s%d", first ? "\"" : ", ", x);
first = false;
}
appendStringInfo(&str, "\": %d", (int) item.ndistinct);
} }
appendStringInfoChar(&str, ']'); appendStringInfoChar(&str, '}');
PG_RETURN_CSTRING(str.data); PG_RETURN_CSTRING(str.data);
} }
......
...@@ -176,8 +176,8 @@ ANALYZE ndistinct; ...@@ -176,8 +176,8 @@ ANALYZE ndistinct;
SELECT stxkind, stxndistinct SELECT stxkind, stxndistinct
FROM pg_statistic_ext WHERE stxrelid = 'ndistinct'::regclass; FROM pg_statistic_ext WHERE stxrelid = 'ndistinct'::regclass;
stxkind | stxndistinct stxkind | stxndistinct
---------+------------------------------------------------------------------------------------------------ ---------+---------------------------------------------------------
{d,f} | [{(b 3 4), 301.000000}, {(b 3 6), 301.000000}, {(b 4 6), 301.000000}, {(b 3 4 6), 301.000000}] {d,f} | {"3, 4": 301, "3, 6": 301, "4, 6": 301, "3, 4, 6": 301}
(1 row) (1 row)
-- Hash Aggregate, thanks to estimates improved by the statistic -- Hash Aggregate, thanks to estimates improved by the statistic
...@@ -242,8 +242,8 @@ ANALYZE ndistinct; ...@@ -242,8 +242,8 @@ ANALYZE ndistinct;
SELECT stxkind, stxndistinct SELECT stxkind, stxndistinct
FROM pg_statistic_ext WHERE stxrelid = 'ndistinct'::regclass; FROM pg_statistic_ext WHERE stxrelid = 'ndistinct'::regclass;
stxkind | stxndistinct stxkind | stxndistinct
---------+---------------------------------------------------------------------------------------------------- ---------+-------------------------------------------------------------
{d,f} | [{(b 3 4), 2550.000000}, {(b 3 6), 800.000000}, {(b 4 6), 1632.000000}, {(b 3 4 6), 10000.000000}] {d,f} | {"3, 4": 2550, "3, 6": 800, "4, 6": 1632, "3, 4, 6": 10000}
(1 row) (1 row)
-- plans using Group Aggregate, thanks to using correct esimates -- plans using Group Aggregate, thanks to using correct esimates
......
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