Fix inappropriate printing of never-measured times in EXPLAIN.
authorTom Lane <[email protected]>
Fri, 12 Aug 2016 16:13:04 +0000 (12:13 -0400)
committerTom Lane <[email protected]>
Fri, 12 Aug 2016 16:13:04 +0000 (12:13 -0400)
EXPLAIN (ANALYZE, TIMING OFF) would print an elapsed time of zero for
a trigger function, because no measurement has been taken but it printed
the field anyway.  This isn't what EXPLAIN does elsewhere, so suppress it.

In the same vein, EXPLAIN (ANALYZE, BUFFERS) with non-text output format
would print buffer I/O timing numbers even when no measurement has been
taken because track_io_timing is off.  That seems not per policy, either,
so change it.

Back-patch to 9.2 where these features were introduced.

Maksim Milyutin

Discussion: <081c0540-ecaa-bd29-3fd2-6358f3b359a9@postgrespro.ru>

src/backend/commands/explain.c

index c50ec0ca207f2abf469d4fb96b7d618e2d16f5ec..3954fda49ac8235d9f12245d22abd4764effa74f 100644 (file)
@@ -23,6 +23,7 @@
 #include "optimizer/clauses.h"
 #include "parser/parsetree.h"
 #include "rewrite/rewriteHandler.h"
+#include "storage/bufmgr.h"
 #include "tcop/tcopprot.h"
 #include "utils/builtins.h"
 #include "utils/json.h"
@@ -630,8 +631,11 @@ report_triggers(ResultRelInfo *rInfo, bool show_relname, ExplainState *es)
                                appendStringInfo(es->str, " for constraint %s", conname);
                        if (show_relname)
                                appendStringInfo(es->str, " on %s", relname);
-                       appendStringInfo(es->str, ": time=%.3f calls=%.0f\n",
-                                                        1000.0 * instr->total, instr->ntuples);
+                       if (es->timing)
+                               appendStringInfo(es->str, ": time=%.3f calls=%.0f\n",
+                                                                1000.0 * instr->total, instr->ntuples);
+                       else
+                               appendStringInfo(es->str, ": calls=%.0f\n", instr->ntuples);
                }
                else
                {
@@ -639,7 +643,8 @@ report_triggers(ResultRelInfo *rInfo, bool show_relname, ExplainState *es)
                        if (conname)
                                ExplainPropertyText("Constraint Name", conname, es);
                        ExplainPropertyText("Relation", relname, es);
-                       ExplainPropertyFloat("Time", 1000.0 * instr->total, 3, es);
+                       if (es->timing)
+                               ExplainPropertyFloat("Time", 1000.0 * instr->total, 3, es);
                        ExplainPropertyFloat("Calls", instr->ntuples, 0, es);
                }
 
@@ -1475,8 +1480,11 @@ ExplainNode(PlanState *planstate, List *ancestors,
                        ExplainPropertyLong("Local Written Blocks", usage->local_blks_written, es);
                        ExplainPropertyLong("Temp Read Blocks", usage->temp_blks_read, es);
                        ExplainPropertyLong("Temp Written Blocks", usage->temp_blks_written, es);
-                       ExplainPropertyFloat("I/O Read Time", INSTR_TIME_GET_MILLISEC(usage->blk_read_time), 3, es);
-                       ExplainPropertyFloat("I/O Write Time", INSTR_TIME_GET_MILLISEC(usage->blk_write_time), 3, es);
+                       if (track_io_timing)
+                       {
+                               ExplainPropertyFloat("I/O Read Time", INSTR_TIME_GET_MILLISEC(usage->blk_read_time), 3, es);
+                               ExplainPropertyFloat("I/O Write Time", INSTR_TIME_GET_MILLISEC(usage->blk_write_time), 3, es);
+                       }
                }
        }