From: | Julien Rouhaud <rjuju123(at)gmail(dot)com> |
---|---|
To: | Dmitry Dolgov <9erthalion6(at)gmail(dot)com> |
Cc: | Pavel Stehule <pavel(dot)stehule(at)gmail(dot)com>, dean(dot)a(dot)rasheed(at)gmail(dot)com, er(at)xs4all(dot)nl, joel(at)compiler(dot)org, pgsql-hackers(at)lists(dot)postgresql(dot)org |
Subject: | Re: Schema variables - new implementation for Postgres 15 |
Date: | 2022-11-04 14:17:13 |
Message-ID: | 20221104141713.4y3dpmlmp73zkwzb@jrouhaud |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
Hi,
On Fri, Nov 04, 2022 at 03:07:48PM +0100, Dmitry Dolgov wrote:
> > On Fri, Nov 04, 2022 at 05:58:06AM +0100, Pavel Stehule wrote:
> > Hi
> >
> > fix clang warning
>
> I've stumbled upon something that looks weird to me (inspired by the
> example from tests):
>
> =# create variable v2 as int;
> =# let v2 = 3;
> =# create view vv2 as select coalesce(v2, 0) + 1000 as result
>
> =# select * from vv2;
> result
> --------
> 1003
>
> =# set force_parallel_mode to on;
> =# select * from vv2;
> result
> --------
> 1000
>
> In the second select the actual work is done from a worker backend.
> Since values of session variables are stored in the backend local
> memory, it's not being shared with the worker and the value is not found
> in the hash map. Does this suppose to be like that?
There's code to serialize and restore all used variables for parallel workers
(see code about PARAM_VARIABLE and queryDesc->num_session_variables /
queryDesc->plannedstmt->sessionVariables). I haven't reviewed that part yet,
but it's supposed to be working. Blind guess would be that it's missing
something in expression walker.
From | Date | Subject | |
---|---|---|---|
Next Message | Antonin Houska | 2022-11-04 14:17:15 | Re: WIP: Aggregation push-down - take2 |
Previous Message | David Christensen | 2022-11-04 14:16:29 | Re: [PATCH] Teach pg_waldump to extract FPIs from the WAL |