Commit 9650830b authored by Tom Lane's avatar Tom Lane

Cause the output from debug_print_parse, debug_print_rewritten, and

debug_print_plan to appear at LOG message level, not DEBUG1 as historically.
Make debug_pretty_print default to on.  Also, cause plans generated via
EXPLAIN to be subject to debug_print_plan.  This is all to make
debug_print_plan a reasonably comfortable substitute for the former behavior
of EXPLAIN VERBOSE.
parent 2aaca8e3
<!-- $PostgreSQL: pgsql/doc/src/sgml/config.sgml,v 1.185 2008/08/15 08:37:41 mha Exp $ --> <!-- $PostgreSQL: pgsql/doc/src/sgml/config.sgml,v 1.186 2008/08/19 18:30:04 tgl Exp $ -->
<chapter Id="runtime-config"> <chapter Id="runtime-config">
<title>Server Configuration</title> <title>Server Configuration</title>
...@@ -2817,7 +2817,6 @@ local0.* /var/log/postgresql ...@@ -2817,7 +2817,6 @@ local0.* /var/log/postgresql
<term><varname>debug_print_parse</varname> (<type>boolean</type>)</term> <term><varname>debug_print_parse</varname> (<type>boolean</type>)</term>
<term><varname>debug_print_rewritten</varname> (<type>boolean</type>)</term> <term><varname>debug_print_rewritten</varname> (<type>boolean</type>)</term>
<term><varname>debug_print_plan</varname> (<type>boolean</type>)</term> <term><varname>debug_print_plan</varname> (<type>boolean</type>)</term>
<term><varname>debug_pretty_print</varname> (<type>boolean</type>)</term>
<indexterm> <indexterm>
<primary><varname>debug_print_parse</> configuration parameter</primary> <primary><varname>debug_print_parse</> configuration parameter</primary>
</indexterm> </indexterm>
...@@ -2827,21 +2826,34 @@ local0.* /var/log/postgresql ...@@ -2827,21 +2826,34 @@ local0.* /var/log/postgresql
<indexterm> <indexterm>
<primary><varname>debug_print_plan</> configuration parameter</primary> <primary><varname>debug_print_plan</> configuration parameter</primary>
</indexterm> </indexterm>
<listitem>
<para>
These parameters enable various debugging output to be emitted.
When set, they print the resulting parse tree, the query rewriter
output, or the execution plan for each executed query.
These messages are emitted at <literal>LOG</> message level, so by
default they will appear in the server log but will not be sent to the
client. You can change that by adjusting
<xref linkend="guc-client-min-messages"> and/or
<xref linkend="guc-log-min-messages">.
These parameters are off by default.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><varname>debug_pretty_print</varname> (<type>boolean</type>)</term>
<indexterm> <indexterm>
<primary><varname>debug_pretty_print</> configuration parameter</primary> <primary><varname>debug_pretty_print</> configuration parameter</primary>
</indexterm> </indexterm>
<listitem> <listitem>
<para> <para>
These parameters enable various debugging output to be emitted. When set, <varname>debug_pretty_print</varname> indents the messages
For each executed query, they print produced by <varname>debug_print_parse</varname>,
the resulting parse tree, the query rewriter output, or the <varname>debug_print_rewritten</varname>, or
execution plan. <varname>debug_pretty_print</varname> indents <varname>debug_print_plan</varname>. This results in more readable
these displays to produce a more readable but much longer but much longer output than the <quote>compact</> format used when
output format. <varname>client_min_messages</varname> or it is off. It is on by default.
<varname>log_min_messages</varname> must be
<literal>DEBUG1</literal> or lower to actually send this output
to the client or the server log, respectively.
These parameters are off by default.
</para> </para>
</listitem> </listitem>
</varlistentry> </varlistentry>
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* Portions Copyright (c) 1994-5, Regents of the University of California * Portions Copyright (c) 1994-5, Regents of the University of California
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/commands/explain.c,v 1.177 2008/08/14 18:47:58 tgl Exp $ * $PostgreSQL: pgsql/src/backend/commands/explain.c,v 1.178 2008/08/19 18:30:04 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -169,7 +169,7 @@ ExplainOneQuery(Query *query, ExplainStmt *stmt, const char *queryString, ...@@ -169,7 +169,7 @@ ExplainOneQuery(Query *query, ExplainStmt *stmt, const char *queryString,
PlannedStmt *plan; PlannedStmt *plan;
/* plan the query */ /* plan the query */
plan = planner(query, 0, params); plan = pg_plan_query(query, 0, params);
/* run it (if needed) and produce output */ /* run it (if needed) and produce output */
ExplainOnePlan(plan, params, stmt, tstate); ExplainOnePlan(plan, params, stmt, tstate);
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/tcop/postgres.c,v 1.555 2008/08/01 13:16:09 alvherre Exp $ * $PostgreSQL: pgsql/src/backend/tcop/postgres.c,v 1.556 2008/08/19 18:30:04 tgl Exp $
* *
* NOTES * NOTES
* this is the "main" module of the postgres backend and * this is the "main" module of the postgres backend and
...@@ -630,13 +630,13 @@ pg_rewrite_query(Query *query) ...@@ -630,13 +630,13 @@ pg_rewrite_query(Query *query)
{ {
List *querytree_list; List *querytree_list;
if (log_parser_stats)
ResetUsage();
if (Debug_print_parse) if (Debug_print_parse)
elog_node_display(DEBUG1, "parse tree", query, elog_node_display(LOG, "parse tree", query,
Debug_pretty_print); Debug_pretty_print);
if (log_parser_stats)
ResetUsage();
if (query->commandType == CMD_UTILITY) if (query->commandType == CMD_UTILITY)
{ {
/* don't rewrite utilities, just dump 'em into result list */ /* don't rewrite utilities, just dump 'em into result list */
...@@ -666,7 +666,7 @@ pg_rewrite_query(Query *query) ...@@ -666,7 +666,7 @@ pg_rewrite_query(Query *query)
#endif #endif
if (Debug_print_rewritten) if (Debug_print_rewritten)
elog_node_display(DEBUG1, "rewritten parse tree", querytree_list, elog_node_display(LOG, "rewritten parse tree", querytree_list,
Debug_pretty_print); Debug_pretty_print);
return querytree_list; return querytree_list;
...@@ -720,7 +720,7 @@ pg_plan_query(Query *querytree, int cursorOptions, ParamListInfo boundParams) ...@@ -720,7 +720,7 @@ pg_plan_query(Query *querytree, int cursorOptions, ParamListInfo boundParams)
* Print plan if debugging. * Print plan if debugging.
*/ */
if (Debug_print_plan) if (Debug_print_plan)
elog_node_display(DEBUG1, "plan", plan, Debug_pretty_print); elog_node_display(LOG, "plan", plan, Debug_pretty_print);
TRACE_POSTGRESQL_QUERY_PLAN_DONE(); TRACE_POSTGRESQL_QUERY_PLAN_DONE();
......
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
* Written by Peter Eisentraut <peter_e@gmx.net>. * Written by Peter Eisentraut <peter_e@gmx.net>.
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/utils/misc/guc.c,v 1.466 2008/08/15 08:37:40 mha Exp $ * $PostgreSQL: pgsql/src/backend/utils/misc/guc.c,v 1.467 2008/08/19 18:30:04 tgl Exp $
* *
*-------------------------------------------------------------------- *--------------------------------------------------------------------
*/ */
...@@ -316,7 +316,7 @@ bool log_duration = false; ...@@ -316,7 +316,7 @@ bool log_duration = false;
bool Debug_print_plan = false; bool Debug_print_plan = false;
bool Debug_print_parse = false; bool Debug_print_parse = false;
bool Debug_print_rewritten = false; bool Debug_print_rewritten = false;
bool Debug_pretty_print = false; bool Debug_pretty_print = true;
bool log_parser_stats = false; bool log_parser_stats = false;
bool log_planner_stats = false; bool log_planner_stats = false;
...@@ -772,7 +772,7 @@ static struct config_bool ConfigureNamesBool[] = ...@@ -772,7 +772,7 @@ static struct config_bool ConfigureNamesBool[] =
}, },
{ {
{"debug_print_parse", PGC_USERSET, LOGGING_WHAT, {"debug_print_parse", PGC_USERSET, LOGGING_WHAT,
gettext_noop("Prints the parse tree to the server log."), gettext_noop("Logs each query's parse tree."),
NULL NULL
}, },
&Debug_print_parse, &Debug_print_parse,
...@@ -780,7 +780,7 @@ static struct config_bool ConfigureNamesBool[] = ...@@ -780,7 +780,7 @@ static struct config_bool ConfigureNamesBool[] =
}, },
{ {
{"debug_print_rewritten", PGC_USERSET, LOGGING_WHAT, {"debug_print_rewritten", PGC_USERSET, LOGGING_WHAT,
gettext_noop("Prints the parse tree after rewriting to server log."), gettext_noop("Logs each query's rewritten parse tree."),
NULL NULL
}, },
&Debug_print_rewritten, &Debug_print_rewritten,
...@@ -788,7 +788,7 @@ static struct config_bool ConfigureNamesBool[] = ...@@ -788,7 +788,7 @@ static struct config_bool ConfigureNamesBool[] =
}, },
{ {
{"debug_print_plan", PGC_USERSET, LOGGING_WHAT, {"debug_print_plan", PGC_USERSET, LOGGING_WHAT,
gettext_noop("Prints the execution plan to server log."), gettext_noop("Logs each query's execution plan."),
NULL NULL
}, },
&Debug_print_plan, &Debug_print_plan,
...@@ -800,7 +800,7 @@ static struct config_bool ConfigureNamesBool[] = ...@@ -800,7 +800,7 @@ static struct config_bool ConfigureNamesBool[] =
NULL NULL
}, },
&Debug_pretty_print, &Debug_pretty_print,
false, NULL, NULL true, NULL, NULL
}, },
{ {
{"log_parser_stats", PGC_SUSET, STATS_MONITORING, {"log_parser_stats", PGC_SUSET, STATS_MONITORING,
......
...@@ -322,7 +322,7 @@ ...@@ -322,7 +322,7 @@
#debug_print_parse = off #debug_print_parse = off
#debug_print_rewritten = off #debug_print_rewritten = off
#debug_print_plan = off #debug_print_plan = off
#debug_pretty_print = off #debug_pretty_print = on
#log_checkpoints = off #log_checkpoints = off
#log_connections = off #log_connections = off
#log_disconnections = off #log_disconnections = off
......
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