mysql流程控制語句包括哪些?

mysql中的流程控制語句包括有:if語句、CASE語句、LOOP語句、while語句、REPEAT語句、LEAVE語句和ITERATE語句,它們都可以來控制程序的流程。

mysql流程控制語句包括哪些?

在存儲過程和自定義函數(shù)中可以使用流程控制語句來控制程序的流程。MySQL 中流程控制語句有::IF語句、CASE語句、LOOP語句、WHILE語句、REPEAT語句、LEAVE語句和ITERATE語句,它們可以進(jìn)行流程控制。(推薦教程:mysql視頻教程

1、IF語句

IF語句用來進(jìn)行條件判斷,根據(jù)不同的條件執(zhí)行不同的操作。該語句在執(zhí)行時首先判斷IF后的條件是否為真,則執(zhí)行THEN后的語句,如果為假則繼續(xù)判斷IF語句直到為真為止,當(dāng)以上都不滿足時則執(zhí)行ELSE語句后的內(nèi)容。IF語句表示形式如下:

IF?condition?THEN 	... ELSE?condition?THEN 	... ELSE 	... END?IF

示例:使用IF語句用來進(jìn)行條件判斷。

--?創(chuàng)建存儲過程 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;  --?調(diào)用存儲過程 CALL?example_if(2);

注意:MySQL 中的?IF( ) 函數(shù)不同于這里的 IF 語句。

2、CASE語句

CASE語句為多分支語句結(jié)構(gòu),該語句首先從WHEN后的VALUE中查找與CASE后的VALUE相等的值,如果查找到則執(zhí)行該分支的內(nèi)容,否則執(zhí)行ELSE后的內(nèi)容。CASE語句表示形式如下:

CASE?value 	WHEN?value?THEN?... 	WHEN?value?THEN?... 	ELSE?... END?CASE

CASE語句另一種語法表示形式如下:

CASE 	WHEN?value?THEN?... 	WHEN?value?THEN?... 	ELSE?... END?CASE

示例:使用CASE語句用來進(jìn)行條件判斷。

--?創(chuàng)建存儲過程 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;  --?調(diào)用存儲過程 CALL?example_case(5);

3、WHILE循環(huán)語句

WHILE循環(huán)語句執(zhí)行時首先判斷condition條件是否為真,如果是則執(zhí)行循環(huán)體,否則退出循環(huán)。該語法表示形式如下:

WHILE?condition?DO ... END?WHILE;

示例:使用WHILE循環(huán)語句執(zhí)行求前100的和。

--?創(chuàng)建存儲過程 CREATE?PROCEDURE?example_while(OUT?sum?INT) BEGIN 	DECLARE?i?INT?DEFAULT?1; 	DECLARE?s?INT?DEFAULT?0;  	WHILE?i?<p><span style="font-size: 18px;"><strong>4、LOOP循環(huán)語句</strong></span></p><p>LOOP循環(huán)沒有內(nèi)置的循環(huán)條件,但可以通過LEAVE語句退出循環(huán)。LOOP語句表示形式如下:</p><pre class="brush:js;toolbar:false;">LOOP 	... END?LOOP

LOOP語句允許某特定語句或語句群的重復(fù)執(zhí)行,實現(xiàn)一個簡單的循環(huán)構(gòu)造,在循環(huán)內(nèi)的語句一直重復(fù)直至循環(huán)被退出,退出循環(huán)應(yīng)用LEAVE語句。

LEAVE語句經(jīng)常和BEGIN…END或者循環(huán)一起使用,其表示形式如下:

LEAVE?label

label是語句中標(biāo)注的名字,這個名字是自定義的。

示例:使用LOOP循環(huán)語句求前100的和。

--?創(chuàng)建存儲過程 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&gt;100?THEN 			--?退出LOOP循環(huán) 			LEAVE?loop_label;?? 		END?IF; 	END?LOOP;  	SET?sum?=?s; END;  --?調(diào)用存儲過程 CALL?example_loop(@sum); SELECT?@sum;

5、REPEAT循環(huán)語句

REPEAT循環(huán)語句先執(zhí)行一次循環(huán)體,之后判斷condition條件是否為真,則退出循環(huán),否則繼續(xù)執(zhí)行循環(huán)。REPEAT語句表示形式如下:

REPEAT 	... 	UNTIL?condition END?REPEAT

示例:使用REPEAT循環(huán)語句求前100的和。

--?創(chuàng)建存儲過程 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?&gt;?100 	END?REPEAT; 	 	SET?sum?=?s; END;  --?調(diào)用存儲過程 CALL?example_repeat(@sum); SELECT?@sum;

6、ITERATE語句

ITERATE語句可以出現(xiàn)在LOOP、REPEAT和WHILE語句內(nèi),其意為“再次循環(huán)”。語句格式如下:

ITERATE?label

該語句的格式與LEAVE大同小異,區(qū)別在于:LEAVE語句是離開一個循環(huán),而ITERATE語句是重新開始一個循環(huán)。

示例:求10以內(nèi)奇數(shù)值的和。

--?創(chuàng)建存儲過程 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?&gt;?10?THEN 			--?退出整個循環(huán) 			LEAVE?loop_label;?? 		END?IF;  		IF?(i?mod?2)?THEN 			SET?s?=?s+i; 		ELSE 			--?退出本次循環(huán),繼續(xù)下一個循環(huán) 			ITERATE??loop_label; 		END?IF;  	END?LOOP;  	SET?sum?=?s; END;  --?調(diào)用存儲過程 CALL?example_iterate(@sum); SELECT?@sum

更多編程相關(guān)知識,請訪問:mysql視頻教程!!

以上就是

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點贊10 分享