Commit b6423e92 authored by Tom Lane's avatar Tom Lane

Doc: fix ancient mistake, or at least obsolete info, in rules example.

The example of expansion of multiple views claimed that the resulting
subquery nest would not get fully flattened because of an aggregate
function.  There's no aggregate in the example, though, only a user
defined function confusingly named MIN().  In a modern server, the
reason for the non-flattening is that MIN() is volatile, but I'm
unsure whether that was true back when this text was written.

Let's reduce the confusion level by using LEAST() instead (which
we didn't have at the time this example was created).  And then
we can just say that the planner will flatten the sub-queries, so
the rewrite system doesn't have to.

Noted by Paul Jungwirth.  This text is old enough to vote, so
back-patch to all supported branches.

Discussion: https://postgr.es/m/CA+renyXZFnmp9PcvX1EVR2dR=XG5e6E-AELr8AHCNZ8RYrpnPw@mail.gmail.com
parent 13e8b2ee
...@@ -341,17 +341,6 @@ CREATE RULE "_RETURN" AS ON SELECT TO myview DO INSTEAD ...@@ -341,17 +341,6 @@ CREATE RULE "_RETURN" AS ON SELECT TO myview DO INSTEAD
than having many different ones that might mix up in mind. than having many different ones that might mix up in mind.
</para> </para>
<para>
For the example, we need a little <literal>min</literal> function that
returns the lower of 2 integer values. We create that as:
<programlisting>
CREATE FUNCTION min(integer, integer) RETURNS integer AS $$
SELECT CASE WHEN $1 &lt; $2 THEN $1 ELSE $2 END
$$ LANGUAGE SQL STRICT;
</programlisting>
</para>
<para> <para>
The real tables we need in the first two rule system descriptions The real tables we need in the first two rule system descriptions
are these: are these:
...@@ -414,7 +403,7 @@ CREATE VIEW shoe_ready AS ...@@ -414,7 +403,7 @@ CREATE VIEW shoe_ready AS
rsh.sh_avail, rsh.sh_avail,
rsl.sl_name, rsl.sl_name,
rsl.sl_avail, rsl.sl_avail,
min(rsh.sh_avail, rsl.sl_avail) AS total_avail least(rsh.sh_avail, rsl.sl_avail) AS total_avail
FROM shoe rsh, shoelace rsl FROM shoe rsh, shoelace rsl
WHERE rsl.sl_color = rsh.slcolor WHERE rsl.sl_color = rsh.slcolor
AND rsl.sl_len_cm &gt;= rsh.slminlen_cm AND rsl.sl_len_cm &gt;= rsh.slminlen_cm
...@@ -593,7 +582,7 @@ SELECT shoe_ready.shoename, shoe_ready.sh_avail, ...@@ -593,7 +582,7 @@ SELECT shoe_ready.shoename, shoe_ready.sh_avail,
rsh.sh_avail, rsh.sh_avail,
rsl.sl_name, rsl.sl_name,
rsl.sl_avail, rsl.sl_avail,
min(rsh.sh_avail, rsl.sl_avail) AS total_avail least(rsh.sh_avail, rsl.sl_avail) AS total_avail
FROM shoe rsh, shoelace rsl FROM shoe rsh, shoelace rsl
WHERE rsl.sl_color = rsh.slcolor WHERE rsl.sl_color = rsh.slcolor
AND rsl.sl_len_cm &gt;= rsh.slminlen_cm AND rsl.sl_len_cm &gt;= rsh.slminlen_cm
...@@ -613,7 +602,7 @@ SELECT shoe_ready.shoename, shoe_ready.sh_avail, ...@@ -613,7 +602,7 @@ SELECT shoe_ready.shoename, shoe_ready.sh_avail,
rsh.sh_avail, rsh.sh_avail,
rsl.sl_name, rsl.sl_name,
rsl.sl_avail, rsl.sl_avail,
min(rsh.sh_avail, rsl.sl_avail) AS total_avail least(rsh.sh_avail, rsl.sl_avail) AS total_avail
FROM (SELECT sh.shoename, FROM (SELECT sh.shoename,
sh.sh_avail, sh.sh_avail,
sh.slcolor, sh.slcolor,
...@@ -640,16 +629,11 @@ SELECT shoe_ready.shoename, shoe_ready.sh_avail, ...@@ -640,16 +629,11 @@ SELECT shoe_ready.shoename, shoe_ready.sh_avail,
</para> </para>
<para> <para>
It turns out that the planner will collapse this tree into a This might look inefficient, but the planner will collapse this into a
two-level query tree: the bottommost <command>SELECT</command> single-level query tree by <quote>pulling up</quote> the subqueries,
commands will be <quote>pulled up</quote> into the middle and then it will plan the joins just as if we'd written them out
<command>SELECT</command> since there's no need to process them manually. So collapsing the query tree is an optimization that the
separately. But the middle <command>SELECT</command> will remain rewrite system doesn't have to concern itself with.
separate from the top, because it contains aggregate functions.
If we pulled those up it would change the behavior of the topmost
<command>SELECT</command>, which we don't want. However,
collapsing the query tree is an optimization that the rewrite
system doesn't have to concern itself with.
</para> </para>
</sect2> </sect2>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment