On Thu, 26 Jun 2025 05:45:12 +0000
"Hayato Kuroda (Fujitsu)" <kuroda.hayato@fujitsu.com> 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 <nagata@sraoss.co.jp>