Commit 871e73bb authored by Alvaro Herrera's avatar Alvaro Herrera

Reformat code examples in plpgsql docs for better readability in PDF output

Erik Rijkers
parent 3efba16d
<!-- $PostgreSQL: pgsql/doc/src/sgml/plpgsql.sgml,v 1.152 2010/04/03 07:22:55 petere Exp $ --> <!-- $PostgreSQL: pgsql/doc/src/sgml/plpgsql.sgml,v 1.153 2010/04/27 14:32:40 alvherre Exp $ -->
<chapter id="plpgsql"> <chapter id="plpgsql">
<title><application>PL/pgSQL</application> - <acronym>SQL</acronym> Procedural Language</title> <title><application>PL/pgSQL</application> - <acronym>SQL</acronym> Procedural Language</title>
...@@ -481,9 +481,11 @@ $$ LANGUAGE plpgsql; ...@@ -481,9 +481,11 @@ $$ LANGUAGE plpgsql;
is with <literal>RETURNS TABLE</>, for example: is with <literal>RETURNS TABLE</>, for example:
<programlisting> <programlisting>
CREATE FUNCTION extended_sales(p_itemno int) RETURNS TABLE(quantity int, total numeric) AS $$ CREATE FUNCTION extended_sales(p_itemno int)
RETURNS TABLE(quantity int, total numeric) AS $$
BEGIN BEGIN
RETURN QUERY SELECT quantity, quantity * price FROM sales WHERE itemno = p_itemno; RETURN QUERY SELECT quantity, quantity * price FROM sales
WHERE itemno = p_itemno;
END; END;
$$ LANGUAGE plpgsql; $$ LANGUAGE plpgsql;
</programlisting> </programlisting>
...@@ -2154,9 +2156,12 @@ BEGIN ...@@ -2154,9 +2156,12 @@ BEGIN
-- Now "mviews" has one record from cs_materialized_views -- Now "mviews" has one record from cs_materialized_views
PERFORM cs_log('Refreshing materialized view ' || quote_ident(mviews.mv_name) || ' ...'); PERFORM cs_log('Refreshing materialized view '
|| quote_ident(mviews.mv_name) || ' ...');
EXECUTE 'TRUNCATE TABLE ' || quote_ident(mviews.mv_name); EXECUTE 'TRUNCATE TABLE ' || quote_ident(mviews.mv_name);
EXECUTE 'INSERT INTO ' || quote_ident(mviews.mv_name) || ' ' || mviews.mv_query; EXECUTE 'INSERT INTO '
|| quote_ident(mviews.mv_name) || ' '
|| mviews.mv_query;
END LOOP; END LOOP;
PERFORM cs_log('Done refreshing materialized views.'); PERFORM cs_log('Done refreshing materialized views.');
...@@ -2495,7 +2500,8 @@ OPEN curs1 FOR SELECT * FROM foo WHERE key = mykey; ...@@ -2495,7 +2500,8 @@ OPEN curs1 FOR SELECT * FROM foo WHERE key = mykey;
<title><command>OPEN FOR EXECUTE</command></title> <title><command>OPEN FOR EXECUTE</command></title>
<synopsis> <synopsis>
OPEN <replaceable>unbound_cursorvar</replaceable> <optional> <optional> NO </optional> SCROLL </optional> FOR EXECUTE <replaceable class="command">query_string</replaceable> <optional> USING <replaceable>expression</replaceable> <optional>, ... </optional> </optional>; OPEN <replaceable>unbound_cursorvar</replaceable> <optional> <optional> NO </optional> SCROLL </optional> FOR EXECUTE <replaceable class="command">query_string</replaceable>
<optional> USING <replaceable>expression</replaceable> <optional>, ... </optional> </optional>;
</synopsis> </synopsis>
<para> <para>
...@@ -2517,7 +2523,8 @@ OPEN <replaceable>unbound_cursorvar</replaceable> <optional> <optional> NO </opt ...@@ -2517,7 +2523,8 @@ OPEN <replaceable>unbound_cursorvar</replaceable> <optional> <optional> NO </opt
<para> <para>
An example: An example:
<programlisting> <programlisting>
OPEN curs1 FOR EXECUTE 'SELECT * FROM ' || quote_ident(tabname) ' WHERE col1 = $1' USING keyvalue; OPEN curs1 FOR EXECUTE 'SELECT * FROM ' || quote_ident(tabname)
|| ' WHERE col1 = $1' USING keyvalue;
</programlisting> </programlisting>
In this example, the table name is inserted into the query textually, In this example, the table name is inserted into the query textually,
so use of <function>quote_ident()</> is recommended to guard against so use of <function>quote_ident()</> is recommended to guard against
...@@ -2810,6 +2817,7 @@ BEGIN ...@@ -2810,6 +2817,7 @@ BEGIN
END; END;
' LANGUAGE plpgsql; ' LANGUAGE plpgsql;
-- need to be in a transaction to use cursors.
BEGIN; BEGIN;
SELECT reffunc2(); SELECT reffunc2();
...@@ -2966,7 +2974,8 @@ RAISE NOTICE 'Calling cs_create_job(%)', v_job_id; ...@@ -2966,7 +2974,8 @@ RAISE NOTICE 'Calling cs_create_job(%)', v_job_id;
This example will abort the transaction with the given error message This example will abort the transaction with the given error message
and hint: and hint:
<programlisting> <programlisting>
RAISE EXCEPTION 'Nonexistent ID --> %', user_id USING HINT = 'Please check your user id'; RAISE EXCEPTION 'Nonexistent ID --> %', user_id
USING HINT = 'Please check your user id';
</programlisting> </programlisting>
</para> </para>
...@@ -3394,7 +3403,8 @@ CREATE UNIQUE INDEX sales_summary_bytime_key ON sales_summary_bytime(time_key); ...@@ -3394,7 +3403,8 @@ CREATE UNIQUE INDEX sales_summary_bytime_key ON sales_summary_bytime(time_key);
-- --
-- Function and trigger to amend summarized column(s) on UPDATE, INSERT, DELETE. -- Function and trigger to amend summarized column(s) on UPDATE, INSERT, DELETE.
-- --
CREATE OR REPLACE FUNCTION maint_sales_summary_bytime() RETURNS TRIGGER AS $maint_sales_summary_bytime$ CREATE OR REPLACE FUNCTION maint_sales_summary_bytime() RETURNS TRIGGER
AS $maint_sales_summary_bytime$
DECLARE DECLARE
delta_time_key integer; delta_time_key integer;
delta_amount_sold numeric(15,2); delta_amount_sold numeric(15,2);
...@@ -3416,7 +3426,8 @@ CREATE OR REPLACE FUNCTION maint_sales_summary_bytime() RETURNS TRIGGER AS $main ...@@ -3416,7 +3426,8 @@ CREATE OR REPLACE FUNCTION maint_sales_summary_bytime() RETURNS TRIGGER AS $main
-- (probably not too onerous, as DELETE + INSERT is how most -- (probably not too onerous, as DELETE + INSERT is how most
-- changes will be made). -- changes will be made).
IF ( OLD.time_key != NEW.time_key) THEN IF ( OLD.time_key != NEW.time_key) THEN
RAISE EXCEPTION 'Update of time_key : % -&gt; % not allowed', OLD.time_key, NEW.time_key; RAISE EXCEPTION 'Update of time_key : % -&gt; % not allowed',
OLD.time_key, NEW.time_key;
END IF; END IF;
delta_time_key = OLD.time_key; delta_time_key = OLD.time_key;
...@@ -3867,7 +3878,7 @@ $$ LANGUAGE plpgsql; ...@@ -3867,7 +3878,7 @@ $$ LANGUAGE plpgsql;
<para> <para>
Another good way to develop in <application>PL/pgSQL</> is with a Another good way to develop in <application>PL/pgSQL</> is with a
GUI database access tool that facilitates development in a GUI database access tool that facilitates development in a
procedural language. One example of such as a tool is procedural language. One example of such a tool is
<application>pgAdmin</>, although others exist. These tools often <application>pgAdmin</>, although others exist. These tools often
provide convenient features such as escaping single quotes and provide convenient features such as escaping single quotes and
making it easier to recreate and debug functions. making it easier to recreate and debug functions.
...@@ -4450,7 +4461,8 @@ BEGIN ...@@ -4450,7 +4461,8 @@ BEGIN
IF a_running_job_count &gt; 0 THEN IF a_running_job_count &gt; 0 THEN
COMMIT; -- free lock<co id="co.plpgsql-porting-commit"> COMMIT; -- free lock<co id="co.plpgsql-porting-commit">
raise_application_error(-20000, 'Unable to create a new job: a job is currently running.'); raise_application_error(-20000,
'Unable to create a new job: a job is currently running.');
END IF; END IF;
DELETE FROM cs_active_job; DELETE FROM cs_active_job;
......
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