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

	<entry>
		<id>http://sqle.ru/index.php?title=SQL/MySQL/Procedure_Function/CASE&amp;diff=5368&amp;oldid=prev</id>
		<title> в 13:46, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL/MySQL/Procedure_Function/CASE&amp;diff=5368&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://sqle.ru/index.php?title=SQL/MySQL/Procedure_Function/CASE&amp;diff=5369&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=SQL/MySQL/Procedure_Function/CASE&amp;diff=5369&amp;oldid=prev"/>
				<updated>2010-05-26T10:17:06Z</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;==CASE Statement with Condition Checks==&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;&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; DELIMITER //&lt;br /&gt;
mysql&amp;gt; CREATE FUNCTION myFunction(delivery_day INT(1),preferred INT(1))&lt;br /&gt;
    -&amp;gt; RETURNS INT(2)&lt;br /&gt;
    -&amp;gt; BEGIN&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt; DECLARE shipping_cost INT(2) DEFAULT 0;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt; CASE&lt;br /&gt;
    -&amp;gt; WHEN preferred = 1 THEN&lt;br /&gt;
    -&amp;gt;         SET shipping_cost = 2;&lt;br /&gt;
    -&amp;gt; WHEN delivery_day = 1 THEN&lt;br /&gt;
    -&amp;gt;         SET shipping_cost = 20;&lt;br /&gt;
    -&amp;gt; WHEN delivery_day = 2 THEN&lt;br /&gt;
    -&amp;gt;         SET shipping_cost = 15;&lt;br /&gt;
    -&amp;gt; WHEN delivery_day = 3 THEN&lt;br /&gt;
    -&amp;gt;         SET shipping_cost = 10;&lt;br /&gt;
    -&amp;gt; ELSE&lt;br /&gt;
    -&amp;gt;         SET shipping_cost = 5;&lt;br /&gt;
    -&amp;gt; END CASE;&lt;br /&gt;
    -&amp;gt; RETURN shipping_cost;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt; END&lt;br /&gt;
    -&amp;gt; //&lt;br /&gt;
Query OK, 0 rows affected (0.01 sec)&lt;br /&gt;
mysql&amp;gt; DELIMITER ;&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; select myFunction(1,1);&lt;br /&gt;
+-----------------+&lt;br /&gt;
| myFunction(1,1) |&lt;br /&gt;
+-----------------+&lt;br /&gt;
|               2 |&lt;br /&gt;
+-----------------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; select myFunction(2,2);&lt;br /&gt;
+-----------------+&lt;br /&gt;
| myFunction(2,2) |&lt;br /&gt;
+-----------------+&lt;br /&gt;
|              15 |&lt;br /&gt;
+-----------------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; select myFunction(3,3);&lt;br /&gt;
+-----------------+&lt;br /&gt;
| myFunction(3,3) |&lt;br /&gt;
+-----------------+&lt;br /&gt;
|              10 |&lt;br /&gt;
+-----------------+&lt;br /&gt;
1 row in set (0.00 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;
==CASE WHEN with ELSE==&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(id int)&lt;br /&gt;
    -&amp;gt; BEGIN&lt;br /&gt;
    -&amp;gt;     CASE&lt;br /&gt;
    -&amp;gt;          WHEN id &amp;lt; 2  THEN&lt;br /&gt;
    -&amp;gt;               select &amp;quot;less than 2&amp;quot;;&lt;br /&gt;
    -&amp;gt;          WHEN id &amp;gt; 2 and id &amp;lt; 5 THEN&lt;br /&gt;
    -&amp;gt;               select &amp;quot;greater than 2 and less than 5&amp;quot;;&lt;br /&gt;
    -&amp;gt;          ELSE&lt;br /&gt;
    -&amp;gt;               select &amp;quot;ELSE&amp;quot;;&lt;br /&gt;
    -&amp;gt;     END CASE;&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;&lt;br /&gt;
mysql&amp;gt; call myProc(1);&lt;br /&gt;
+-------------+&lt;br /&gt;
| less than 2 |&lt;br /&gt;
+-------------+&lt;br /&gt;
| less than 2 |&lt;br /&gt;
+-------------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
Query OK, 0 rows affected (0.01 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; call myProc(3);&lt;br /&gt;
+--------------------------------+&lt;br /&gt;
| greater than 2 and less than 5 |&lt;br /&gt;
+--------------------------------+&lt;br /&gt;
| greater than 2 and less than 5 |&lt;br /&gt;
+--------------------------------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&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;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==For checking a uniform condition you may use the CASE construct==&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;&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; DELIMITER //&lt;br /&gt;
mysql&amp;gt; CREATE FUNCTION myFunction (delivery_day INT(1)) RETURNS INT(2)&lt;br /&gt;
    -&amp;gt; BEGIN&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt; DECLARE shipping_cost INT(2) DEFAULT 0;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt; CASE delivery_day&lt;br /&gt;
    -&amp;gt; WHEN 1 THEN&lt;br /&gt;
    -&amp;gt;         SET shipping_cost = 20;&lt;br /&gt;
    -&amp;gt; WHEN 2 THEN&lt;br /&gt;
    -&amp;gt;         SET shipping_cost = 15;&lt;br /&gt;
    -&amp;gt; WHEN 3 THEN&lt;br /&gt;
    -&amp;gt;         SET shipping_cost = 10;&lt;br /&gt;
    -&amp;gt; ELSE&lt;br /&gt;
    -&amp;gt;         SET shipping_cost = 5;&lt;br /&gt;
    -&amp;gt; END CASE;&lt;br /&gt;
    -&amp;gt; RETURN shipping_cost;&lt;br /&gt;
    -&amp;gt;&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(1);&lt;br /&gt;
+---------------+&lt;br /&gt;
| myFunction(1) |&lt;br /&gt;
+---------------+&lt;br /&gt;
|            20 |&lt;br /&gt;
+---------------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; select myFunction(2);&lt;br /&gt;
+---------------+&lt;br /&gt;
| myFunction(2) |&lt;br /&gt;
+---------------+&lt;br /&gt;
|            15 |&lt;br /&gt;
+---------------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; select myFunction(3);&lt;br /&gt;
+---------------+&lt;br /&gt;
| myFunction(3) |&lt;br /&gt;
+---------------+&lt;br /&gt;
|            10 |&lt;br /&gt;
+---------------+&lt;br /&gt;
1 row in set (0.00 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;
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 CASE WHEN condition statement in a procedure==&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; CREATE PROCEDURE myProc(id int)&lt;br /&gt;
    -&amp;gt; BEGIN&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;     CASE&lt;br /&gt;
    -&amp;gt;          WHEN id &amp;lt; 2  THEN&lt;br /&gt;
    -&amp;gt;               select &amp;quot;less than 2&amp;quot;;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;          WHEN id &amp;gt; 2 and id &amp;lt; 5 THEN&lt;br /&gt;
    -&amp;gt;               select &amp;quot;greater than 2 and less than 5&amp;quot;;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;          WHEN id &amp;gt; 5 THEN&lt;br /&gt;
    -&amp;gt;               select &amp;quot;greater than 5&amp;quot;;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;     END CASE;&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(2);&lt;br /&gt;
ERROR 1339 (20000): Case not found for CASE statement&lt;br /&gt;
mysql&amp;gt; call myProc(20);&lt;br /&gt;
+----------------+&lt;br /&gt;
| greater than 5 |&lt;br /&gt;
+----------------+&lt;br /&gt;
| greater than 5 |&lt;br /&gt;
+----------------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&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;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Using CASE WHEN statement in a procedure==&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(customer_status VARCHAR(10))&lt;br /&gt;
    -&amp;gt; BEGIN&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;     CASE customer_status&lt;br /&gt;
    -&amp;gt;          WHEN &amp;quot;PLATINUM&amp;quot;  THEN&lt;br /&gt;
    -&amp;gt;               select &amp;quot;PLATINUM&amp;quot;;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;          WHEN &amp;quot;GOLD&amp;quot; THEN&lt;br /&gt;
    -&amp;gt;               select &amp;quot;GOLD&amp;quot;;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;          WHEN &amp;quot;SILVER&amp;quot; THEN&lt;br /&gt;
    -&amp;gt;               select &amp;quot;SILVER&amp;quot;;&lt;br /&gt;
    -&amp;gt;&lt;br /&gt;
    -&amp;gt;          WHEN &amp;quot;BRONZE&amp;quot; THEN&lt;br /&gt;
    -&amp;gt;               select &amp;quot;BRONZE&amp;quot;;&lt;br /&gt;
    -&amp;gt;     END CASE;&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(&amp;quot;BRONZE&amp;quot;);&lt;br /&gt;
+--------+&lt;br /&gt;
| BRONZE |&lt;br /&gt;
+--------+&lt;br /&gt;
| BRONZE |&lt;br /&gt;
+--------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
mysql&amp;gt; call myProc(&amp;quot;GOLD&amp;quot;);&lt;br /&gt;
+------+&lt;br /&gt;
| GOLD |&lt;br /&gt;
+------+&lt;br /&gt;
| GOLD |&lt;br /&gt;
+------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
mysql&amp;gt;&lt;br /&gt;
mysql&amp;gt; drop procedure myProc;&lt;br /&gt;
Query OK, 0 rows affected (0.00 sec)&lt;br /&gt;
        &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>