Re: Add PortalDrop in exec_execute_message

Поиск
Список
Период
Сортировка
От Alvaro Herrera
Тема Re: Add PortalDrop in exec_execute_message
Дата
Msg-id 202105262059.dnf27qpnccuv@alvherre.pgsql
обсуждение исходный текст
Ответ на Re: Add PortalDrop in exec_execute_message  (Yura Sokolov <y.sokolov@postgrespro.ru>)
Ответы Re: Add PortalDrop in exec_execute_message  (Tom Lane <tgl@sss.pgh.pa.us>)
Re: Add PortalDrop in exec_execute_message  (Yura Sokolov <y.sokolov@postgrespro.ru>)
Список pgsql-hackers
On 2021-May-25, Yura Sokolov wrote:

> Tom Lane писал 2021-05-21 21:23:
> > Yura Sokolov <y.sokolov@postgrespro.ru> writes:
> > > I propose to add PortalDrop at the 'if (completed)' branch of
> > > exec_execute_message.
> > 
> > This violates our wire protocol specification, which
> > specifically says
> > 
> >     If successfully created, a named portal object lasts till the end of
> >     the current transaction, unless explicitly destroyed. An unnamed
> >     portal is destroyed at the end of the transaction, or as soon as the
> >     next Bind statement specifying the unnamed portal as destination is
> >     issued. (Note that a simple Query message also destroys the unnamed
> >     portal.)
> > 
> > I'm inclined to think that your complaint would be better handled
> > by having the client send a portal-close command, if it's not
> > going to do something else immediately.
> 
> I thought about it as well. Then, if I understand correctly,
> PQsendQueryGuts and PQsendQueryInternal in pipeline mode should send
> "close portal" (CP) message after "execute" message, right?

I don't think they should do that.  The portal remains open, and the
libpq interface does that.  The portal gets closed at end of transaction
without the need for any client message.  I think if the client wanted
to close the portal ahead of time, it would need a new libpq entry point
to send the message to do that.

(I didn't add a Close Portal message to PQsendQueryInternal in pipeline
mode precisely because there is no such message in PQsendQueryGuts.
I think it would be wrong to unconditionally add a Close Portal message
to any of those places.)

-- 
Álvaro Herrera                            39°49'30"S 73°17'W



В списке pgsql-hackers по дате отправления:

Предыдущее
От: Bruce Momjian
Дата:
Сообщение: Re: storing an explicit nonce
Следующее
От: Bruce Momjian
Дата:
Сообщение: Re: storing an explicit nonce