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

說明:
順序結(jié)構(gòu):程序從上往下依次執(zhí)行
分支結(jié)構(gòu):程序按條件進行選擇執(zhí)行,從兩條或多條路徑中選擇一條執(zhí)行
循環(huán)結(jié)構(gòu):程序滿足一定條件下,重復執(zhí)行一組語句

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

特點:

1、if函數(shù)

功能:實現(xiàn)簡單雙分支
語法:
if(條件,值1,值2)
位置:
應用在begin end中或外面,可以作為表達式放在任何位置

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

功能:實現(xiàn)多分支
語法1:
case 表達式或字段
when 值1 then 語句1;
when 值2 then 語句2;
..
else 語句n;
end [case];

語法2:
case
when 條件1 then 語句1;
when 條件2 then 語句2;
..
else 語句n;
end [case];

位置:
可以放在任何位置,
如果放在begin end 外面,作為表達式結(jié)合著其他語句使用
如果放在begin end 里面,一般作為獨立的語句使用

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

功能:實現(xiàn)多分支
語法:
if 條件1 then 語句1;
elseif 條件2 then 語句2;
...
else 語句n;
end if;
位置:
只能放在begin end中

案例
#案例1:創(chuàng)建函數(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ù),實現(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)$

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

分類:

while、loop、repeat

對比:

①這三種循環(huán)都可以省略名稱,但如果循環(huán)中添加了循環(huán)控制語句(leave或iterate)則必須添加名稱
②loop 一般用于實現(xiàn)簡單的死循環(huán)
while 先判斷后執(zhí)行
repeat 先執(zhí)行后判斷,無條件至少執(zhí)行一次

1、while

語法:
【名稱:】while 循環(huán)條件 do
循環(huán)體
end while 【名稱】;

2、loop

語法:
【名稱:】loop
循環(huán)體
end loop 【名稱】;

3、repeat

語法:
【名稱:】repeat
循環(huán)體
until 結(jié)束條件
end repeat 【名稱】;

二、循環(huán)控制語句

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

#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)$
#插入了100條

/*

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

    //插入
    
    i++;

}

*/


#2.添加leave語句

#案例:批量插入,根據(jù)次數(shù)插入到admin表中多條記錄,如果次數(shù)>20則停止
TRUNCATE TABLE admin$
DROP 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 admin$
DROP 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;
    }
    插入
    
}

*/

經(jīng)典實例

/*一、已知表stringcontent
其中字段:
id 自增長
content varchar(20)

向該表插入指定個數(shù)的,隨機的字符串
*/
DROP TABLE IF EXISTS stringcontent;
CREATE TABLE stringcontent(
    id INT PRIMARY KEY AUTO_INCREMENT,
    content VARCHAR(20)
    
);
DELIMITER $
CREATE PROCEDURE test_randstr_insert(IN insertCount INT)
BEGIN
    DECLARE i INT DEFAULT 1;
    DECLARE str VARCHAR(26) DEFAULT 'abcdefghijklmnopqrstuvwxyz';
    DECLARE startIndex INT;#代表初始索引
    DECLARE len INT;#代表截取的字符長度
    WHILE i<=insertcount DO
        SET startIndex=FLOOR(RAND()*26+1);#代表初始索引,隨機范圍1-26
        SET len=FLOOR(RAND()*(20-startIndex+1)+1);#代表截取長度,隨機范圍1-(20-startIndex+1)
        INSERT INTO stringcontent(content) VALUES(SUBSTR(str,startIndex,len));
        SET i=i+1;
    END WHILE;

END $

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

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

  • 流程控制結(jié)構(gòu) /*順序、分支、循環(huán) */ 一、分支結(jié)構(gòu) 1.if函數(shù) /*語法:if(條件,值1,值2)功能:實現(xiàn)...
    majorty閱讀 471評論 0 0
  • 說明: 順序結(jié)構(gòu):程序從上往下依次執(zhí)行 分支結(jié)構(gòu):程序按條件進行選擇執(zhí)行,從兩條或多條路徑中選擇一條執(zhí)行 循環(huán)結(jié)構(gòu)...
    leeqico閱讀 478評論 0 0
  • 任何 PHP 腳本都是由一系列語句構(gòu)成的。一條語句可以是一個賦值語句,一個函數(shù)調(diào)用,一個循環(huán),甚至一個什么也不做的...
    dptms閱讀 1,077評論 0 3
  • swift和OC一樣提供了if /switch / for /while /repeat- while語句 if ...
    個位數(shù)余額閱讀 268評論 0 0
  • 在任何一門設(shè)計語言中,都需要支持滿足程序結(jié)構(gòu)化所需要的三種基本結(jié)構(gòu)、順序結(jié)構(gòu)、分支結(jié)構(gòu)(選擇結(jié)構(gòu)或條件結(jié)構(gòu))和循環(huán)...
    楠哥哥_0b86閱讀 480評論 0 0

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