mysql数据库入门教程(15):流程控制结构
一.流程控制結構介紹
#流程控制結構
/*
順序、分支、循環
*/
1.分支結構
#1.if函數
/*
語法:if(條件,值1,值2)
功能:實現雙分支
應用在begin end中或外面
如果條件成立 返回值1,否則返回值2
*/
#2.case結構
/*
語法:
情況1:類似于switch
case 變量或表達式
when 值1 then 返回語句1;
when 值2 then 返回語句2;
…
else 語句n;
end
情況2:
case
when 條件1 then 返回語句1;
when 條件2 then 返回語句2;
…
else 語句n;
end
應用在begin end 中或外面
*/
#3.if結構
/*
語法:
if 條件1 then 語句1;
elseif 條件2 then 語句2;
…
else 語句n;
end if;
功能:類似于多重if
只能應用在begin end 中
*/
2.循環結構
/*
分類:
while、loop、repeat
循環控制:
iterate類似于 continue,繼續,結束本次循環,繼續下一次
leave 類似于 break,跳出,結束當前所在的循環
*/
#1.while
/*
語法:
【標簽:】while 循環條件 do
循環體;
end while【 標簽】;
聯想:
while(循環條件){
循環體;
}
*/
#2.loop
/*
語法:
【標簽:】loop
循環體;
end loop 【標簽】;
可以用來模擬簡單的死循環
*/
#3.repeat
/*
語法:
【標簽:】repeat
循環體;
until 結束循環的條件
end repeat 【標簽】;
*/
二.分支結構案例
必須在cmd中運行,流程控制結構是在函數或者存儲里面的。
1.if案例
#案例1:創建函數,實現傳入成績,如果成績>90,返回A,如果成績>80,返回B,如果成績>60,返回C,否則返回D
DELIMITER $ CREATE FUNCTION test_if(score FLOAT) RETURNS CHAR BEGINDECLARE 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:創建存儲過程,如果工資<2000,則刪除,如果5000>工資>2000,則漲工資1000,否則漲工資500
DELIMITER $ CREATE PROCEDURE test_if_pro(IN sal DOUBLE) BEGINIF 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)$2.case案例
#案例1:創建函數,實現傳入成績,如果成績>90,返回A,如果成績>80,返回B,如果成績>60,返回C,否則返回D
三.循環結構(while)案例
#案例:批量插入,根據次數插入到admin表中多條記錄
這是存儲過程,因為沒有返回
可以加上標簽
#1.沒有添加循環控制語句 #案例:批量插入,根據次數插入到admin表中多條記錄 DROP PROCEDURE pro_while1$ CREATE PROCEDURE pro_while1(IN insertCount INT) BEGINDECLARE i INT DEFAULT 1;a:WHILE i<=insertCount DOINSERT INTO admin(username,`password`) VALUES(CONCAT('Rose',i),'666');SET i=i+1;END WHILE a;END $CALL pro_while1(100)$#2.添加leave語句
這是存儲沒有返回
#3.添加iterate語句
#案例:批量插入,根據次數插入到admin表中多條記錄,只插入偶數次 TRUNCATE TABLE admin$ DROP PROCEDURE test_while1$ CREATE PROCEDURE test_while1(IN insertCount INT) BEGINDECLARE i INT DEFAULT 0;a:WHILE i<=insertCount DOSET 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)$
電氣工程的計算機萌新,寫博文不容易。如果你覺得本文對你有用,請點個贊支持下,謝謝。
總結
以上是生活随笔為你收集整理的mysql数据库入门教程(15):流程控制结构的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 吉林省长春市九台区邮编是多少
- 下一篇: 全国商赛小组取名我们小组三个女生,想要冲