Re: BUG #17235: PQsendQuery (with two sql) after PQenterPipelineMode cause ERROR

From: Alvaro Herrera <alvherre(at)alvh(dot)no-ip(dot)org>
To: "David G(dot) Johnston" <david(dot)g(dot)johnston(at)gmail(dot)com>
Cc: Daniel Verite <daniel(at)manitou-mail(dot)org>, RekGRpth <rekgrpth(at)gmail(dot)com>, PostgreSQL mailing lists <pgsql-bugs(at)lists(dot)postgresql(dot)org>
Subject: Re: BUG #17235: PQsendQuery (with two sql) after PQenterPipelineMode cause ERROR
Date: 2021-10-20 19:34:31
Message-ID: 202110201934.4w3rlxmsbf5b@alvherre.pgsql
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

On 2021-Oct-20, David G. Johnston wrote:

> It seems desirable to talk about the multi-command limitation directly in
> the libpq chapter of the documentation and only refer to the protocol
> documentation for "additional reading". We should not assume the reader of
> this material knows that extended protocol implies single command.

Sure.

> It is too late to change now but why did we feel the need to make
> PQsendQuery work in Pipeline mode at all?

Mostly, I saw no reason not to make it work for the common case.

> Lacking a decent answer it is probably worth saying that while
> PQsendQuery works it behaves like PQsendQueryParams without any
> parameters specified. In particular, it does not allow for multiple
> commands to be specified in the query.

Sure.

> Combine that with a mention that all interactions with the server are done
> using v3 of the extended protocol. Maybe by rewriting the above as:
>
> "While in pipeline mode, communication with the server is done using v3 of
> the extended query protocol. This means that the pipeline API can be used
> to communicate with all servers that support the protocol. It also means
> that it is not possible to include multiple commands in a single query (see
> the note in Protocol XRef for details)."

Hmm, this seems to get into too much detail for that particular spot.
Also, this paragraph is there precisely to let the reader know they can
use the pipeline mode with older server versions. I don't disagree with
rewording the paragraph in a similar way to what you outline in the
first two phrases (not exactly that though), but the third one you
propose seems a bit out of place. Why not add a few words to
PQsendQuery() doc blurb instead?

--
Álvaro Herrera 39°49'30"S 73°17'W — https://www.EnterpriseDB.com/

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message David G. Johnston 2021-10-20 19:48:10 Re: BUG #17235: PQsendQuery (with two sql) after PQenterPipelineMode cause ERROR
Previous Message David G. Johnston 2021-10-20 15:01:33 Re: BUG #17235: PQsendQuery (with two sql) after PQenterPipelineMode cause ERROR