On Thu, 26 Jun 2025 05:45:12 +0000
"Hayato Kuroda (Fujitsu)" <[email protected]> wrote:
> Dear Nagata-san,
>
> > As I understand it, the current patch aims to allow continuation only after
> > SQL-level
> > errors, such as constraint violations. That seems reasonable, as it can
> > simulate
> > the
> > behavior of applications that ignore or retry such errors (even though
> > retries are
> > not
> > implemented in the current patch).
>
> Yes, no one has objections to retry in this case. This is a main part of the
> proposal.,
As I understand it, the proposed --continue-on-error option does not retry the
transaction
in any case; it simply gives up on the transaction. That is, when an SQL-level
error occurs,
the transaction is reported as "failed" rather than "retried", and the random
state is discarded.
>
> > However, I'm not sure it's reasonable to allow continuation after other
> > types of
> > errors,
> > such as misuse of meta-commands or unexpected errors during their execution,
> > since these
> > wouldn't simulate any real application behavior and would more likely
> > indicate a
> > failure
> > in the benchmarking process itself.
>
> I have a concern for \gset metacommand.
> According to the doc and source code, \gset assumed that executed command
> surely
> returns a tuple:
>
> ```
> if (meta == META_GSET && ntuples != 1)
> {
> /* under \gset, report the
> error */
> pg_log_error("client %d script
> %d command %d query %d: expected one row, got %d",
>
> st->id, st->use_file, st->command, qrynum, PQntuples(res));
> st->estatus =
> ESTATUS_META_COMMAND_ERROR;
> goto error;
> }
> ```
>
> But sometimes the SQL may not be able to return tuples or return multiple
> ones due
> to the concurrent transactions. I feel retrying the transaction is very useful
> in this case.
You can use \aset command instead to avoid the error of pgbench. If the query
doesn't
return any row, a subsecuent SQL command trying to use the varialbe will fail,
but this
would be ignored without terminating the benchmark when the --coneinue-on-error
option
enabled.
> Anyway, we must confirm the opinion from the proposer.
+1
Best regards,
Yugo Nagata
--
Yugo Nagata <[email protected]>