From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Paul A Jungwirth <pj(at)illuminatedcomputing(dot)com> |
Cc: | pgsql <pgsql-general(at)postgresql(dot)org> |
Subject: | Re: Rules documentation example |
Date: | 2019-11-11 18:38:49 |
Message-ID: | 14490.1573497529@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-general |
Paul A Jungwirth <pj(at)illuminatedcomputing(dot)com> writes:
> I'm reading the docs about the Postgres Rule system here:
> https://www.postgresql.org/docs/12/rules-views.html
> That page says:
>> It turns out that the planner will collapse this tree into a two-level query tree: the bottommost SELECT commands will be “pulled up” into the middle SELECT since there's no need to process them separately. But the middle SELECT will remain separate from the top, because it contains aggregate functions. If we pulled those up it would change the behavior of the topmost SELECT, which we don't want.
> But I don't see an aggregate function. Is it referring to MIN?
Perhaps. Digging in the git history, that text seems to be mine
(commit 1045304a3), but the example that it's talking about was
pre-existing. I think I might've just misread it. It's also
likely (assuming that I was documenting a behavior that I actually
saw at the time) that the real issue is that MIN(), as presented,
defaults to being volatile which would also prevent such flattening.
But this example is so old that I'm not sure whether that particular
optimization behavior existed then.
I'm inclined to:
(1) get rid of the example's MIN() function in favor of using
LEAST(), which is standard and less confusing;
(2) change the text to just say that the planner flattens these
subqueries, so we don't pay any execution-time penalty from the
way the view replacements are handled.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Christoph Moench-Tegeder | 2019-11-11 19:00:07 | Re: security on user for replication |
Previous Message | Paul A Jungwirth | 2019-11-11 18:03:13 | Rules documentation example |