Re: Early WIP/PoC for inlining CTEs
От | Andreas Karlsson |
---|---|
Тема | Re: Early WIP/PoC for inlining CTEs |
Дата | |
Msg-id | 97ba944c-5a30-bed5-8ec5-62196b6b0825@proxel.se обсуждение исходный текст |
Ответ на | Re: Early WIP/PoC for inlining CTEs (Andrew Gierth <andrew@tao11.riddles.org.uk>) |
Список | pgsql-hackers |
On 1/1/19 3:18 AM, Andrew Gierth wrote: > I had a comment around here which seems to have been lost: > > * Secondly, views (and explicit subqueries) currently have > * different behaviour w.r.t. SELECT FOR UPDATE than CTEs do. A > * FOR UPDATE clause is treated as extending into views and > * subqueries, but not into CTEs. We preserve this distinction > * by not trying to push rowmarks into the new subquery. > > This comment seems to me to be worth preserving (unless this behavior is > changed). What I'm referring to is the following, which is unchanged by > the patch: > > create table t1 as select 123 as a; > create view v1 as select * from t1; > select * from t1 for update; -- locks row in t1 > select * from t1 for update of t1; -- locks row in t1 > select * from v1 for update; -- locks row in t1 > select * from v1 for update of v1; -- locks row in t1 > select * from (select * from t1) s1 for update; -- locks row in t1 > select * from (select * from t1) s1 for update of s1; -- locks row in t1 > with c1 as (select * from t1) > select * from c1 for update; -- does NOT lock anything at all > with c1 as (select * from t1) > select * from c1 for update of c1; -- parse-time error > > (Obviously, inlining decisions should not change what gets locked; > the behavior here should not be changed unless it is changed for both > inlined and non-inlined CTEs.) I see, I misread the comment. I will re-add it, possibly with some word smithing. Thanks! Andreas
В списке pgsql-hackers по дате отправления: