<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="cs">
	<id>http://postgres.cz/index.php?action=history&amp;feed=atom&amp;title=Assignment_statement</id>
	<title>Assignment statement - Historie editací</title>
	<link rel="self" type="application/atom+xml" href="http://postgres.cz/index.php?action=history&amp;feed=atom&amp;title=Assignment_statement"/>
	<link rel="alternate" type="text/html" href="http://postgres.cz/index.php?title=Assignment_statement&amp;action=history"/>
	<updated>2026-05-21T19:31:28Z</updated>
	<subtitle>Historie editací této stránky</subtitle>
	<generator>MediaWiki 1.43.3</generator>
	<entry>
		<id>http://postgres.cz/index.php?title=Assignment_statement&amp;diff=252&amp;oldid=prev</id>
		<title>85.160.90.236 v 4. 6. 2007, 08:51</title>
		<link rel="alternate" type="text/html" href="http://postgres.cz/index.php?title=Assignment_statement&amp;diff=252&amp;oldid=prev"/>
		<updated>2007-06-04T08:51:56Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nová stránka&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Assign a value to an SQL variable&lt;br /&gt;
&lt;br /&gt;
PL/pgPSM supports three forms of assignment statement:&lt;br /&gt;
* singleton variable assignment&lt;br /&gt;
* multiple variable assignment (compatible with standard SQL/PSM)&lt;br /&gt;
* multiple variable assignment (compatible with DB2 and MySQL)&lt;br /&gt;
&lt;br /&gt;
Multiple variable assignement like DB2 is evaluated repeatable from left to right and it&amp;#039;s equeal to a sequence of singleton variable assignment. In standard multiple variable assignment is expression list evaluated first and result is assigned to target variable list. It&amp;#039;s allways faster than multiple variable assignment like DB2 and it is preferred.&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
CREATE OR REPLACE FUNCTION foo()&lt;br /&gt;
RETURNS void AS &lt;br /&gt;
$$&lt;br /&gt;
  BEGIN&lt;br /&gt;
    DECLARE a, b, c int;&lt;br /&gt;
    -- singleton variable assignment&lt;br /&gt;
    SET a = 0; SET b = a + 1; SET c = b + 1;&lt;br /&gt;
    -- multiple variable assignment (DB2 and MySQL style)&lt;br /&gt;
    SET a = 0, b = a + 1, c = b + 1;&lt;br /&gt;
    -- multiple variable assignment (ANSI)&lt;br /&gt;
    SET (a,b,c) = (0, 0 + 1, 0 + 2);&lt;br /&gt;
    -- assign subquery&lt;br /&gt;
    SET a = (SELECT f.a FROM Foo f);&lt;br /&gt;
    SET (a, b, c) = (SELECT f.a, f.b, f.c FROM Foo f);&lt;br /&gt;
  END;&lt;br /&gt;
$$ LANGUAGE plpgpsm;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;Syntax&amp;#039;&amp;#039;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
SET &amp;#039;(&amp;#039; variable [, variable [, ...]] &amp;#039;)&amp;#039; = &amp;#039;(&amp;#039; expression &amp;#039;)&amp;#039; &amp;#039;;&amp;#039;&lt;br /&gt;
SET variable &amp;#039;=&amp;#039; expression [, variable &amp;#039;=&amp;#039; expression [, ...]] &amp;#039;;&amp;#039;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>85.160.90.236</name></author>
	</entry>
</feed>