Heim  >  Artikel  >  Datenbank  >  Wie wird die MySQL-CASE-Anweisung in gespeicherten Prozeduren verwendet?

Wie wird die MySQL-CASE-Anweisung in gespeicherten Prozeduren verwendet?

WBOY
WBOYnach vorne
2023-08-22 13:37:07750Durchsuche

MySQL CASE语句如何在存储过程中使用?

Tatsächlich hat die CASE-Anweisung die Funktion der IF-THEN-ELSE-Anweisung. Die Syntax lautet wie folgt: Die

CASE
WHEN condition_1 THEN
   {...statements to execute when condition_1 is TRUE...}
[ WHEN condition_2 THEN
   {...statements to execute when condition_2 is TRUE...} ]
[ WHEN condition_n THEN
   {...statements to execute when condition_n is TRUE...} ]
[ ELSE
   {...statements to execute when all conditions were FALSE...} ]
END CASE;

CASE-Anweisung führt die ELSE-Klausel aus, wenn keine WHEN-Klausel ausgeführt wird.

Um die Verwendung der CASE-Anweisung in gespeicherten MySQL-Prozeduren zu demonstrieren, haben wir die folgende gespeicherte Prozedur basierend auf der Tabelle „student_info“ mit den unten gezeigten Werten erstellt:

mysql> Select * from student_info;
+------+---------+------------+------------+
| id   | Name    | Address    | Subject    |
+------+---------+------------+------------+
| 101  | YashPal | Amritsar   | History    |
| 105  | Gaurav  | Jaipur     | Literature |
| 125  | Raman   | Shimla     | Computers  |
+------+---------+------------+------------+
3 rows in set (0.00 sec)

Die folgende Abfrage erstellt einen Speicher mit dem Namen „coursedetails_CASE“. Prozedur, die eine CASE-Anweisung enthält: −

mysql> Delimiter //
mysql> CREATE PROCEDURE coursedetails_CASE(IN S_subject Varchar(20), OUT S_Course Varchar(50))
   -> BEGIN
   -> DECLARE SUB VArchar(20);
   -> SELECT SUBJECT INTO Sub
   -> FROM Student_Info WHERE S_Subject = Subject;
   -> CASE S_Subject WHEN 'Computers' THEN
   -> SET S_Course = 'B.Tech(CSE)’;
   -> WHEN 'History' THEN
   -> SET S_Course = 'Masters in History';
   -> WHEN 'Literature' THEN
   -> SET S_Course = 'Masters in English';
   -> ELSE
   -> SET S_Course = 'Subject not in the table';
   -> END CASE ;
   -> END //
Query OK, 0 rows affected (0.11 sec)

Wenn wir nun diese Prozedur aufrufen, sehen wir das folgende Ergebnis: −

mysql> DELIMITER ;
mysql> CALL coursedetails_CASE ('Computers', @S_course);
Query OK, 1 row affected (0.08 sec)

mysql> Select @S_Course;
+-------------+
| @S_Course   |
+-------------+
| B.Tech(CSE) |
+-------------+
1 row in set (0.00 sec)

mysql> CALL coursedetails_CASE ('literature', @S_course);
Query OK, 1 row affected (0.00 sec)

mysql> Select @S_Course;
+--------------------+
| @S_Course          |
+--------------------+
| Masters in English |
+--------------------+
1 row in set (0.00 sec)

mysql> CALL coursedetails_CASE ('Math', @S_course);
Query OK, 0 rows affected (0.00 sec)

mysql> Select @S_Course;
+--------------------------------+
| @S_Course                      |
+--------------------------------+
| Subject Not in the table       |
+--------------------------------+
1 row in set (0.00 sec)

mysql> CALL coursedetails_CASE ('History', @S_course);
Query OK, 1 row affected (0.01 sec)

mysql> Select @S_Course;
+--------------------+
| @S_Course          |
+--------------------+
| Masters in History |
+--------------------+
1 row in set (0.00 sec)

Das obige ist der detaillierte Inhalt vonWie wird die MySQL-CASE-Anweisung in gespeicherten Prozeduren verwendet?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:tutorialspoint.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen