diff --git a/src/bin/psql/describe.c b/src/bin/psql/describe.c index 3a749d1029..3642205b23 100644 --- a/src/bin/psql/describe.c +++ b/src/bin/psql/describe.c @@ -1839,7 +1839,7 @@ describeOneTableDetails(const char *schemaname, { /* use "pretty" mode for expression to avoid excessive parentheses */ appendPQExpBufferStr(&buf, - ",\n (SELECT substring(pg_catalog.pg_get_expr(d.adbin, d.adrelid, true) for 128)" + ",\n (SELECT pg_catalog.pg_get_expr(d.adbin, d.adrelid, true)" "\n FROM pg_catalog.pg_attrdef d" "\n WHERE d.adrelid = a.attrelid AND d.adnum = a.attnum AND a.atthasdef)" ",\n a.attnotnull"); @@ -2042,7 +2042,8 @@ describeOneTableDetails(const char *schemaname, { char *identity; char *generated; - char *default_str = ""; + char *default_str; + bool mustfree = false; printTableAddCell(&cont, PQgetvalue(res, i, attcoll_col), false, false); @@ -2058,12 +2059,15 @@ describeOneTableDetails(const char *schemaname, else if (identity[0] == ATTRIBUTE_IDENTITY_BY_DEFAULT) default_str = "generated by default as identity"; else if (generated[0] == ATTRIBUTE_GENERATED_STORED) - default_str = psprintf("generated always as (%s) stored", PQgetvalue(res, i, attrdef_col)); + { + default_str = psprintf("generated always as (%s) stored", + PQgetvalue(res, i, attrdef_col)); + mustfree = true; + } else - /* (note: above we cut off the 'default' string at 128) */ default_str = PQgetvalue(res, i, attrdef_col); - printTableAddCell(&cont, default_str, false, generated[0] ? true : false); + printTableAddCell(&cont, default_str, false, mustfree); } /* Info for index columns */