<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL%2FMySQL%2FProcedure_Function%2FVariable_Scope</id>
		<title>SQL/MySQL/Procedure Function/Variable Scope - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.sqle.ru/index.php?action=history&amp;feed=atom&amp;title=SQL%2FMySQL%2FProcedure_Function%2FVariable_Scope"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL/MySQL/Procedure_Function/Variable_Scope&amp;action=history"/>
		<updated>2026-05-24T23:10:13Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL/MySQL/Procedure_Function/Variable_Scope&amp;diff=5392&amp;oldid=prev</id>
		<title> в 13:46, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL/MySQL/Procedure_Function/Variable_Scope&amp;diff=5392&amp;oldid=prev"/>
				<updated>2010-05-26T13:46:00Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 13:46, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.sqle.ru/index.php?title=SQL/MySQL/Procedure_Function/Variable_Scope&amp;diff=5393&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=SQL/MySQL/Procedure_Function/Variable_Scope&amp;diff=5393&amp;oldid=prev"/>
				<updated>2010-05-26T10:17:10Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Inner variable shadows the outter variable==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; delimiter $$&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; CREATE PROCEDURE myProc()&lt;br /&gt;
    -&amp;gt; BEGIN&lt;br /&gt;
    -&amp;gt;         DECLARE my_variable VARCHAR(20);&lt;br /&gt;
    -&amp;gt;         SET my_variable=&amp;quot;This value was set in the outer block&amp;quot;;&lt;br /&gt;
    -&amp;gt;         BEGIN&lt;br /&gt;
    -&amp;gt;                 DECLARE my_variable VARCHAR(20);&lt;br /&gt;
    -&amp;gt;                 SET my_variable=&amp;quot;This value was set in the inner block&amp;quot;;&lt;br /&gt;
    -&amp;gt;         END;&lt;br /&gt;
    -&amp;gt;         SELECT my_variable, &amp;quot;Can&amp;quot;&amp;quot;t see changes made in the inner block&amp;quot;;&lt;br /&gt;
    -&amp;gt; END$$&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; delimiter ;&lt;br /&gt;
mysql&amp;gt; call myProc();&lt;br /&gt;
+----------------------+-------------------------------------------+&lt;br /&gt;
| my_variable          | Can&amp;quot;t see changes made in the inner block |&lt;br /&gt;
+----------------------+-------------------------------------------+&lt;br /&gt;
| This value was set i | Can&amp;quot;t see changes made in the inner block |&lt;br /&gt;
+----------------------+-------------------------------------------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
Query OK, 0 rows affected, 2 warnings (0.00 sec)&lt;br /&gt;
mysql&amp;gt; drop procedure myProc;&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
        &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==LOCAL, SESSION, AND GLOBAL VARIABLES IN MYSQL==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; SET @cost = 5, @cost1 = 8.00;&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; select @cost;&lt;br /&gt;
+-------+&lt;br /&gt;
| @cost |&lt;br /&gt;
+-------+&lt;br /&gt;
| 5     |&lt;br /&gt;
+-------+&lt;br /&gt;
1 row in set (0.01 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; select @cost1;&lt;br /&gt;
+--------+&lt;br /&gt;
| @cost1 |&lt;br /&gt;
+--------+&lt;br /&gt;
| 8.00   |&lt;br /&gt;
+--------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
        &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Nested blocks==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; delimiter $$&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; CREATE PROCEDURE myProc()&lt;br /&gt;
    -&amp;gt; BEGIN&lt;br /&gt;
    -&amp;gt;         DECLARE my_variable VARCHAR(20);&lt;br /&gt;
    -&amp;gt;         SET my_variable=&amp;quot;This value was set in the outer block&amp;quot;;&lt;br /&gt;
    -&amp;gt;         BEGIN&lt;br /&gt;
    -&amp;gt;                 DECLARE my_variable VARCHAR(20);&lt;br /&gt;
    -&amp;gt;                 SET my_variable=&amp;quot;This value was set in the inner block&amp;quot;;&lt;br /&gt;
    -&amp;gt;         END;&lt;br /&gt;
    -&amp;gt;         SELECT my_variable, &amp;quot;Can&amp;quot;&amp;quot;t see changes made in the inner block&amp;quot;;&lt;br /&gt;
    -&amp;gt; END$$&lt;br /&gt;
Query OK, 0 rows affected (0.02 sec)&lt;br /&gt;
mysql&amp;gt; delimiter ;&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; call myProc();&lt;br /&gt;
+----------------------+-------------------------------------------+&lt;br /&gt;
| my_variable          | Can&amp;quot;t see changes made in the inner block |&lt;br /&gt;
+----------------------+-------------------------------------------+&lt;br /&gt;
| This value was set i | Can&amp;quot;t see changes made in the inner block |&lt;br /&gt;
+----------------------+-------------------------------------------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
Query OK, 0 rows affected, 2 warnings (0.00 sec)&lt;br /&gt;
mysql&amp;gt; drop procedure myProc;&lt;br /&gt;
Query OK, 0 rows affected (0.02 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
        &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Using Declare statement to declare the local variable==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; DELIMITER //&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; CREATE FUNCTION myFunction (cost DECIMAL(10,2)) RETURNS DECIMAL(10,2)&lt;br /&gt;
    -&amp;gt; BEGIN&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;     DECLARE shipping_cost DECIMAL(10,2);&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;     SET shipping_cost = 0;&lt;br /&gt;
    -&amp;gt;     IF cost &amp;lt; 25.00 THEN&lt;br /&gt;
    -&amp;gt;             SET shipping_cost = 10.00;&lt;br /&gt;
    -&amp;gt;     ELSEIF cost &amp;lt; 100.00 THEN&lt;br /&gt;
    -&amp;gt;             SET shipping_cost = 20.00;&lt;br /&gt;
    -&amp;gt;     ELSEIF cost &amp;lt; 200.00 THEN&lt;br /&gt;
    -&amp;gt;             SET shipping_cost = 30.00;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;     ELSE&lt;br /&gt;
    -&amp;gt;             SET shipping_cost = 40.00;&lt;br /&gt;
    -&amp;gt;     END IF;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;     RETURN shipping_cost;&lt;br /&gt;
    -&amp;gt; END&lt;br /&gt;
    -&amp;gt; //&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
mysql&amp;gt; DELIMITER ;&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; select myFunction(123.123);&lt;br /&gt;
+---------------------+&lt;br /&gt;
| myFunction(123.123) |&lt;br /&gt;
+---------------------+&lt;br /&gt;
|               30.00 |&lt;br /&gt;
+---------------------+&lt;br /&gt;
1 row in set, 1 warning (0.02 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; drop function myFunction;&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
        &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Variable scope==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; delimiter $$&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; CREATE PROCEDURE myProc()&lt;br /&gt;
    -&amp;gt; BEGIN&lt;br /&gt;
    -&amp;gt;         DECLARE outer_variable VARCHAR(20);&lt;br /&gt;
    -&amp;gt;         BEGIN&lt;br /&gt;
    -&amp;gt;                 DECLARE inner_variable VARCHAR(20);&lt;br /&gt;
    -&amp;gt;                 SET inner_variable=&amp;quot;This is my private data&amp;quot;;&lt;br /&gt;
    -&amp;gt;         END;&lt;br /&gt;
    -&amp;gt;         SELECT inner_variable,&amp;quot; This statement causes an error &amp;quot;;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt; END$$&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; delimiter ;&lt;br /&gt;
mysql&amp;gt; call myProc();&lt;br /&gt;
ERROR 1054 (42S22): Unknown column &amp;quot;inner_variable&amp;quot; in &amp;quot;field list&amp;quot;&lt;br /&gt;
mysql&amp;gt; drop procedure myProc;&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
        &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>