MySQL流程控制語句
在MySQL中,常見的過程式SQL語句可以用在一個儲存過程體中。其中包括:IF語句、CASE語句、LOOP語句、WHILE語句、REPEAT語句、LEAVE語句和ITERATE語句,它們可以進行流程控制。
1、IF語句
IF語句用來進行條件判斷,根據不同的條件執行不同的操作。該語句在執行時首先判斷IF後的條件是否為真,則執行THEN後的語句,如果為假則繼續判斷IF語句直到為真為止,當以上都不滿足時則執行ELSE語句後的內容。IF語句表示形式如下:
IF condition THEN
...
ELSE condition THEN
...
ELSE
...
END IF
示例:
-- 建立儲存過程
CREATE PROCEDURE example_if (IN x INT)
BEGIN
IF x = 1 THEN
SELECT 1;
ELSEIF x = 2 THEN
SELECT 2;
ELSE
SELECT 3;
END IF;
END;
-- 呼叫儲存過程
CALL example_if(2);
2、CASE語句
CASE語句為多分支語句結構,該語句首先從WHEN後的VALUE中查詢與CASE後的VALUE相等的值,如果查詢到則執行該分支的內容,否則執行ELSE後的內容。CASE語句表示形式如下:
CASE value
WHEN value THEN ...
WHEN value THEN ...
ELSE ...
END CASE
CASE語句另一種語法表示形式如下:
CASE
WHEN value THEN ...
WHEN value THEN ...
ELSE ...
END CASE
示例:使用CASE語句用來進行條件判斷。
-- 建立儲存過程 CREATE PROCEDURE example_case(IN x INT) BEGIN CASE x WHEN 1 THEN SELECT 1; WHEN 2 THEN SELECT 2; ELSE SELECT 3; END CASE; END; -- 呼叫儲存過程 CALL example_case(5);
3、WHILE迴圈語句
WHILE迴圈語句執行時首先判斷condition條件是否為真,如果是則執行迴圈體,否則退出迴圈。該語法表示形式如下:
WHILE condition DO
...
END WHILE;
示例:使用WHILE迴圈語句執行求前100的和。
-- 建立儲存過程
CREATE PROCEDURE example_while(OUT sum INT)
BEGIN
DECLARE i INT DEFAULT 1;
DECLARE s INT DEFAULT 0;
WHILE i <= 100 DO
SET s = s+i;
SET i = i+1;
END WHILE;
SET sum = s;
END;
-- 呼叫儲存過程
CALL example_while(@sum);
SELECT @sum;
4、LOOP迴圈語句
LOOP迴圈沒有內建的迴圈條件,但可以通過LEAVE語句退出迴圈。LOOP語句表示形式如下:
LOOP
...
END LOOP
LOOP語句允許某特定語句或語句群的重複執行,實現一個簡單的迴圈構造,在迴圈內的語句一直重複直至迴圈被退出,退出迴圈應用LEAVE語句。
LEAVE語句經常和BEGIN...END或者迴圈一起使用,其表示形式如下:
LEAVE label
label是語句中標註的名字,這個名字是自定義的。
示例:使用LOOP迴圈語句求前100的和。
-- 建立儲存過程
CREATE PROCEDURE example_loop(OUT sum INT)
BEGIN
DECLARE i INT DEFAULT 1;
DECLARE s INT DEFAULT 0;
loop_label:LOOP
SET s = s+i;
SET i = i+1;
IF i>100 THEN
-- 退出LOOP迴圈
LEAVE loop_label;
END IF;
END LOOP;
SET sum = s;
END;
-- 呼叫儲存過程
CALL example_loop(@sum);
SELECT @sum;
5、REPEAT迴圈語句
REPEAT迴圈語句先執行一次迴圈體,之後判斷condition條件是否為真,則退出迴圈,否則繼續執行迴圈。REPEAT語句表示形式如下:
REPEAT
...
UNTIL condition
END REPEAT
示例:使用REPEAT迴圈語句求前100的和。
-- 建立儲存過程
CREATE PROCEDURE example_repeat(OUT sum INT)
BEGIN
DECLARE i INT DEFAULT 1;
DECLARE s INT DEFAULT 0;
REPEAT
SET s = s+i;
SET i = i+1;
UNTIL i > 100
END REPEAT;
SET sum = s;
END;
-- 呼叫儲存過程
CALL example_repeat(@sum);
SELECT @sum;
6、ITERATE語句
ITERATE語句可以出現在LOOP、REPEAT和WHILE語句內,其意為“再次迴圈”。語句格式如下:
ITERATE label
該語句的格式與LEAVE大同小異,區別在於:LEAVE語句是離開一個迴圈,而ITERATE語句是重新開始一個迴圈。
示例:求10以內奇數值的和。
-- 建立儲存過程
CREATE PROCEDURE example_iterate(OUT sum INT)
BEGIN
DECLARE i INT DEFAULT 0;
DECLARE s INT DEFAULT 0;
loop_label:LOOP
SET i = i+1;
IF i > 10 THEN
-- 退出整個迴圈
LEAVE loop_label;
END IF;
IF (i mod 2) THEN
SET s = s+i;
ELSE
-- 退出本次迴圈,繼續下一個迴圈
ITERATE loop_label;
END IF;
END LOOP;
SET sum = s;
END;
-- 呼叫儲存過程
CALL example_iterate(@sum);
SELECT @sum;