Commit 0898d71f authored by Tom Lane's avatar Tom Lane

Marginal improvements to documentation of plpgsql's OPEN cursor statement.

Rearrange text to improve clarity, and add an example of implicit reference
to a plpgsql variable in a bound cursor's query.  Byproduct of some work
I'd done on the "named cursor parameters" patch before giving up on it.
parent b4aec388
...@@ -2720,7 +2720,7 @@ END; ...@@ -2720,7 +2720,7 @@ END;
DECLARE DECLARE
curs1 refcursor; curs1 refcursor;
curs2 CURSOR FOR SELECT * FROM tenk1; curs2 CURSOR FOR SELECT * FROM tenk1;
curs3 CURSOR (key integer) IS SELECT * FROM tenk1 WHERE unique1 = key; curs3 CURSOR (key integer) FOR SELECT * FROM tenk1 WHERE unique1 = key;
</programlisting> </programlisting>
All three of these variables have the data type <type>refcursor</>, All three of these variables have the data type <type>refcursor</>,
but the first can be used with any query, while the second has but the first can be used with any query, while the second has
...@@ -2836,31 +2836,43 @@ OPEN <replaceable>bound_cursorvar</replaceable> <optional> ( <replaceable>argume ...@@ -2836,31 +2836,43 @@ OPEN <replaceable>bound_cursorvar</replaceable> <optional> ( <replaceable>argume
cursor cannot be open already. A list of actual argument value cursor cannot be open already. A list of actual argument value
expressions must appear if and only if the cursor was declared to expressions must appear if and only if the cursor was declared to
take arguments. These values will be substituted in the query. take arguments. These values will be substituted in the query.
</para>
<para>
The query plan for a bound cursor is always considered cacheable; The query plan for a bound cursor is always considered cacheable;
there is no equivalent of <command>EXECUTE</command> in this case. there is no equivalent of <command>EXECUTE</command> in this case.
Notice that <literal>SCROLL</> and Notice that <literal>SCROLL</> and <literal>NO SCROLL</> cannot be
<literal>NO SCROLL</> cannot be specified, as the cursor's scrolling specified in <command>OPEN</>, as the cursor's scrolling
behavior was already determined. behavior was already determined.
</para> </para>
<para> <para>
Note that because variable substitution is done on the bound Examples (these use the cursor declaration examples above):
cursor's query, there are two ways to pass values into the cursor:
either with an explicit argument to <command>OPEN</>, or
implicitly by referencing a <application>PL/pgSQL</> variable
in the query. However, only variables declared before the bound
cursor was declared will be substituted into it. In either case
the value to be passed is determined at the time of the
<command>OPEN</>.
</para>
<para>
Examples:
<programlisting> <programlisting>
OPEN curs2; OPEN curs2;
OPEN curs3(42); OPEN curs3(42);
</programlisting> </programlisting>
</para> </para>
<para>
Because variable substitution is done on a bound cursor's query,
there are really two ways to pass values into the cursor: either
with an explicit argument to <command>OPEN</>, or implicitly by
referencing a <application>PL/pgSQL</> variable in the query.
However, only variables declared before the bound cursor was
declared will be substituted into it. In either case the value to
be passed is determined at the time of the <command>OPEN</>.
For example, another way to get the same effect as the
<literal>curs3</> example above is
<programlisting>
DECLARE
key integer;
curs4 CURSOR FOR SELECT * FROM tenk1 WHERE unique1 = key;
BEGIN
key := 42;
OPEN curs4;
</programlisting>
</para>
</sect3> </sect3>
</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