<?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=MySQL_Tutorial%2FProcedure_Function%2FVariable_Scope</id>
		<title>MySQL Tutorial/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=MySQL_Tutorial%2FProcedure_Function%2FVariable_Scope"/>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=MySQL_Tutorial/Procedure_Function/Variable_Scope&amp;action=history"/>
		<updated>2026-05-24T13:12:28Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.sqle.ru/index.php?title=MySQL_Tutorial/Procedure_Function/Variable_Scope&amp;diff=728&amp;oldid=prev</id>
		<title> в 13:44, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=MySQL_Tutorial/Procedure_Function/Variable_Scope&amp;diff=728&amp;oldid=prev"/>
				<updated>2010-05-26T13:44:56Z</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:44, 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=MySQL_Tutorial/Procedure_Function/Variable_Scope&amp;diff=729&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.sqle.ru/index.php?title=MySQL_Tutorial/Procedure_Function/Variable_Scope&amp;diff=729&amp;oldid=prev"/>
				<updated>2010-05-26T09:53:34Z</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;
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;&amp;lt;/source&amp;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;
&amp;lt;p&amp;gt;MySQL has three different kinds of variables:&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;Local variables&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;Local variables are set in the scope of a statement or block of statements.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;Once that statement or block of statements has completed, the variable goes out of scope.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;Session variables&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;Session variables are set in the scope of your session with the MySQL server.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;A session starts with a connection to the server and ends when the connection is closed.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;Variables go out of scope once the connection is terminated.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;Variables created during your connection cannot be referenced from other sessions.&amp;lt;/p&amp;gt;&lt;br /&gt;
&amp;lt;p&amp;gt;To declare or reference a session variable, prefix the variable name with an @ symbol:&amp;lt;/p&amp;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;
SET @count = 100;.&amp;lt;/source&amp;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;
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;&amp;lt;/source&amp;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;
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)&amp;lt;/source&amp;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;
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;&amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>