From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Dave Cramer <davecramer(at)postgres(dot)rocks> |
Cc: | James Pang <jamespang886(at)gmail(dot)com>, pgsql-jdbc(at)lists(dot)postgresql(dot)org, Laurenz Albe <laurenz(dot)albe(at)cybertec(dot)at> |
Subject: | Re: cached plan must not change result type |
Date: | 2024-03-29 16:21:06 |
Message-ID: | 2950.1711729266@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-admin pgsql-jdbc |
Dave Cramer <davecramer(at)postgres(dot)rocks> writes:
> This is really an issue that needs to be solved in the backend. The error
> is coming from PostgreSQL and what should happen is that when you alter a
> table that a server prepared statement relies on the backend should send a
> message to tell us that all of the prepared statements that rely on are now
> invalid and we can reprepare them.
This is something that can't change without a wire protocol change.
There is nothing in the protocol that allows the backend to send out
a message like "oh, that Describe I sent you awhile back? It might
be a lie now" at random times. Also, what do you want to do about
race conditions --- that is, what if you fire off an Execute only
to find that one of those messages was already in flight to you?
A non-racy way to handle it might be for Bind/Execute to refuse to
run the query if its output has changed since the last Describe,
which we could check after acquiring table locks during Bind.
But we'd want to define "refuse" in a way that doesn't abort the
transaction, and that's a concept that doesn't exist in the
protocol at all.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Dave Cramer | 2024-03-29 16:48:26 | Re: cached plan must not change result type |
Previous Message | Dave Cramer | 2024-03-29 15:45:09 | Re: cached plan must not change result type |
From | Date | Subject | |
---|---|---|---|
Next Message | Dave Cramer | 2024-03-29 16:48:26 | Re: cached plan must not change result type |
Previous Message | Dave Cramer | 2024-03-29 15:45:09 | Re: cached plan must not change result type |