真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

mysql流程控制語句是什么-創(chuàng)新互聯(lián)

這篇文章將為大家詳細講解有關(guān)mysql流程控制語句是什么,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)公司專注于企業(yè)全網(wǎng)整合營銷推廣、網(wǎng)站重做改版、彭州網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、HTML5建站、購物商城網(wǎng)站建設(shè)、集團公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為彭州等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

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

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

1、IF語句

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

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

示例:使用IF語句用來進行條件判斷。

-- 創(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語句用來進行條件判斷。

-- 創(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 <= 100 DO
		SET s = s+i;
		SET i = i+1;
	END WHILE;

	SET sum = s;
END;

-- 調(diào)用存儲過程
CALL example_while(@sum);
SELECT @sum;

4、LOOP循環(huán)語句

LOOP循環(huán)沒有內(nèi)置的循環(huán)條件,但可以通過LEAVE語句退出循環(huán)。LOOP語句表示形式如下:

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是語句中標注的名字,這個名字是自定義的。

示例:使用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>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 > 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 > 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流程控制語句是什么就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


當前名稱:mysql流程控制語句是什么-創(chuàng)新互聯(lián)
標題鏈接:http://weahome.cn/article/dodpig.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部