Visibility of a local variable

Started by Alejandro Burnealmost 2 years ago4 messagesbugs
Jump to latest
#1Alejandro Burne
adburne@gmail.com

A local variable, created within a transaction, continues to persist
(without value) after the transaction has ended.

select version();

PostgreSQL 12.15 (Ubuntu 12.15-1.pgdg18.04+1) on x86_64-pc-linux-gnu,
compiled by gcc (Ubuntu 7.5.0-3ubuntu1~18.04) 7.5.0, 64-bit

select current_setting('my.var1');

ERROR: parámetro de configuración «my.var1» no reconocido SQL state: 42704
(as expected)

begin;
set local my.var1 = true;
commit;

(everything ok)

select current_setting('my.var1');

returns an empty field (current_setting)

It should return the same error as in the first statement

Greetings, Alejandro

#2David G. Johnston
david.g.johnston@gmail.com
In reply to: Alejandro Burne (#1)
Re: Visibility of a local variable

On Monday, June 3, 2024, Alejandro Burne <adburne@gmail.com> wrote:

A local variable, created within a transaction, continues to persist
(without value) after the transaction has ended.

This is under-documented but at present there is no plan to change this
long-standing behavior, just document it better.

Once a session knows a variable exists it cannot be made to not exist.
Only set back to its default empty string value (since custom variables are
only of type text)

David J.

#3Tom Lane
tgl@sss.pgh.pa.us
In reply to: David G. Johnston (#2)
Re: Visibility of a local variable

"David G. Johnston" <david.g.johnston@gmail.com> writes:

On Monday, June 3, 2024, Alejandro Burne <adburne@gmail.com> wrote:

A local variable, created within a transaction, continues to persist
(without value) after the transaction has ended.

This is under-documented but at present there is no plan to change this
long-standing behavior, just document it better.

Keep in mind that this entire behavior (ie the ability to create GUCs
not declared in the C code) is an undocumented abuse of the GUC
system. We probably can't get rid of it at this late date, but
we're very unlikely to make any incompatible changes in the behavior.

regards, tom lane

#4David G. Johnston
david.g.johnston@gmail.com
In reply to: Tom Lane (#3)
Re: Visibility of a local variable

On Tue, Jun 4, 2024 at 10:05 AM Tom Lane <tgl@sss.pgh.pa.us> wrote:

"David G. Johnston" <david.g.johnston@gmail.com> writes:

On Monday, June 3, 2024, Alejandro Burne <adburne@gmail.com> wrote:

A local variable, created within a transaction, continues to persist
(without value) after the transaction has ended.

This is under-documented but at present there is no plan to change this
long-standing behavior, just document it better.

Keep in mind that this entire behavior (ie the ability to create GUCs
not declared in the C code) is an undocumented abuse of the GUC
system. We probably can't get rid of it at this late date, but
we're very unlikely to make any incompatible changes in the behavior.

No, but this is another indication that there is demand for Pavel's schema
variables feature that it would be nice to point to instead of saying this
usable behavior is unsupported and has no supported alternatives.

David J.