mysql中的流程控制語句包括有:IF語句、CASE語句、LOOP語句、WHILE語句、REPEAT語句、LEAVE語句和ITERATE語句,它們都可以來控製程式的流程。
在預存程序和自訂函數中可以使用流程控制語句來控製程式的流程。 MySQL 中流程控制語句有::IF語句、CASE語句、LOOP語句、WHILE語句、REPEAT語句、LEAVE語句和ITERATE語句,它們可以進行流程控制。 (推薦教學:mysql影片教學)
1、IF語句
IF語句用來進行條件判斷,根據不同的條件執行不同的操作。該語句在執行時先判斷IF後的條件是否為真,則執行THEN後的語句,如果為假則繼續判斷IF語句直到為真為止,當以上都不滿足時則執行ELSE語句後的內容。 IF語句表示形式如下:
IF condition THEN ... ELSE condition THEN ... ELSE ... END IF
範例:使用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);
注意:MySQL 中的 IF( ) 函數不同於這裡的 IF 語句。
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
更多程式相關知識,請造訪:程式設計學習網站! !
以上是mysql流程控制語句包括哪些?的詳細內容。更多資訊請關注PHP中文網其他相關文章!