mysql流程控制結(jié)構(gòu)

流程控制結(jié)構(gòu)

/*
順序、分支、循環(huán)

*/

一、分支結(jié)構(gòu)

1.if函數(shù)

/*
語法:if(條件,值1,值2)
功能:實(shí)現(xiàn)雙分支
應(yīng)用在begin end中或外面

*/

2.case結(jié)構(gòu)

/*
語法:
情況1:類似于switch
case 變量或表達(dá)式
when 值1 then 語句1;
when 值2 then 語句2;
...
else 語句n;
end

情況2:
case
when 條件1 then 語句1;
when 條件2 then 語句2;
...
else 語句n;
end

應(yīng)用在begin end 中或外面

*/

3.if結(jié)構(gòu)

/*
語法:
if 條件1 then 語句1;
elseif 條件2 then 語句2;
....
else 語句n;
end if;
功能:類似于多重if

只能應(yīng)用在begin end 中

*/

案例1:創(chuàng)建函數(shù),實(shí)現(xiàn)傳入成績,如果成績>90,返回A,如果成績>80,返回B,如果成績>60,返回C,否則返回D

CREATE FUNCTION test_if(score FLOAT) RETURNS CHAR
BEGIN
DECLARE ch CHAR DEFAULT 'A';
IF score>90 THEN SET ch='A';
ELSEIF score>80 THEN SET ch='B';
ELSEIF score>60 THEN SET ch='C';
ELSE SET ch='D';
END IF;
RETURN ch;

END $

SELECT test_if(87)$

案例2:創(chuàng)建存儲過程,如果工資<2000,則刪除,如果5000>工資>2000,則漲工資1000,否則漲工資500

CREATE PROCEDURE test_if_pro(IN sal DOUBLE)
BEGIN
IF sal<2000 THEN DELETE FROM employees WHERE employees.salary=sal;
ELSEIF sal>=2000 AND sal<5000 THEN UPDATE employees SET salary=salary+1000 WHERE employees.salary=sal;
ELSE UPDATE employees SET salary=salary+500 WHERE employees.salary=sal;
END IF;

END $

CALL test_if_pro(2100)$

案例1:創(chuàng)建函數(shù),實(shí)現(xiàn)傳入成績,如果成績>90,返回A,如果成績>80,返回B,如果成績>60,返回C,否則返回D

CREATE FUNCTION test_case(score FLOAT) RETURNS CHAR
BEGIN
DECLARE ch CHAR DEFAULT 'A';

CASE 
WHEN score>90 THEN SET ch='A';
WHEN score>80 THEN SET ch='B';
WHEN score>60 THEN SET ch='C';
ELSE SET ch='D';
END CASE;

RETURN ch;

END $

SELECT test_case(56)$

二、循環(huán)結(jié)構(gòu)

/*
分類:
while、loop、repeat

循環(huán)控制:

iterate類似于 continue,繼續(xù),結(jié)束本次循環(huán),繼續(xù)下一次
leave 類似于 break,跳出,結(jié)束當(dāng)前所在的循環(huán)

*/

1.while

/*

語法:

【標(biāo)簽:】while 循環(huán)條件 do
循環(huán)體;
end while【 標(biāo)簽】;

聯(lián)想:

while(循環(huán)條件){

循環(huán)體;

}

*/

2.loop

/*

語法:
【標(biāo)簽:】loop
循環(huán)體;
end loop 【標(biāo)簽】;

可以用來模擬簡單的死循環(huán)

*/

3.repeat

/*
語法:
【標(biāo)簽:】repeat
循環(huán)體;
until 結(jié)束循環(huán)的條件
end repeat 【標(biāo)簽】;

*/

1.沒有添加循環(huán)控制語句

案例:批量插入,根據(jù)次數(shù)插入到admin表中多條記錄

DROP PROCEDURE pro_while1$
CREATE PROCEDURE pro_while1(IN insertCount INT)
BEGIN
DECLARE i INT DEFAULT 1;
WHILE i<=insertCount DO
INSERT INTO admin(username,password) VALUES(CONCAT('Rose',i),'666');
SET i=i+1;
END WHILE;

END $

CALL pro_while1(100)$

/*

int i=1;
while(i<=insertcount){

//插入

i++;

}

*/

2.添加leave語句

案例:批量插入,根據(jù)次數(shù)插入到admin表中多條記錄,如果次數(shù)>20則停止

TRUNCATE TABLE adminDROP PROCEDURE test_while1
CREATE PROCEDURE test_while1(IN insertCount INT)
BEGIN
DECLARE i INT DEFAULT 1;
a:WHILE i<=insertCount DO
INSERT INTO admin(username,password) VALUES(CONCAT('xiaohua',i),'0000');
IF i>=20 THEN LEAVE a;
END IF;
SET i=i+1;
END WHILE a;
END $

CALL test_while1(100)$

3.添加iterate語句

案例:批量插入,根據(jù)次數(shù)插入到admin表中多條記錄,只插入偶數(shù)次

TRUNCATE TABLE adminDROP PROCEDURE test_while1
CREATE PROCEDURE test_while1(IN insertCount INT)
BEGIN
DECLARE i INT DEFAULT 0;
a:WHILE i<=insertCount DO
SET i=i+1;
IF MOD(i,2)!=0 THEN ITERATE a;
END IF;

    INSERT INTO admin(username,`password`) VALUES(CONCAT('xiaohua',i),'0000');
    
END WHILE a;

END $

CALL test_while1(100)$

/*

int i=0;
while(i<=insertCount){
i++;
if(i%2==0){
continue;
}
插入

}

*/

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 介紹PL/SQL的流程控制語句, 包括如下三類: l 控制語句: IF 語句 l 循環(huán)語句: LOOP語句, EX...
    WindRiseed閱讀 510評論 0 0
  • ORACLE自學(xué)教程 --create tabletestone ( id number, --序號usernam...
    落葉寂聊閱讀 1,252評論 0 0
  • MYSQL 基礎(chǔ)知識 1 MySQL數(shù)據(jù)庫概要 2 簡單MySQL環(huán)境 3 數(shù)據(jù)的存儲和獲取 4 MySQL基本操...
    Kingtester閱讀 8,067評論 5 115
  • 月亮對你說 年年元宵 今又元宵 心盼元宵節(jié) 又怕元宵到 同在京城咫尺遠(yuǎn) 見靣難 難似萬水千...
    風(fēng)起龍飛閱讀 502評論 27 46
  • 再見了相互嫌棄的老同學(xué), 再見了 來不及說出的謝謝, 我相信我們還會(huì)再見 我相信 我會(huì)一直想念, 我相信我們都會(huì)很...
    我很方閱讀 182評論 0 0

友情鏈接更多精彩內(nèi)容