日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

Mysql流程控制结构

發(fā)布時(shí)間:2025/3/15 数据库 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Mysql流程控制结构 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

流程控制結(jié)構(gòu)
順序、分支、循環(huán)

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

  • if函數(shù)
語(yǔ)法:if(條件,1,值2) 功能:實(shí)現(xiàn)雙分支 應(yīng)用在begin end中或外面
  • case結(jié)構(gòu)
語(yǔ)法: 情況1:類似于switch case 變量或表達(dá)式 when 值1 then 語(yǔ)句1; when 值2 then 語(yǔ)句2; ... else 語(yǔ)句n; end 情況2case when 條件1 then 語(yǔ)句1; when 條件2 then 語(yǔ)句2; ... else 語(yǔ)句n; end 應(yīng)用在begin end 中或外面
  • if結(jié)構(gòu)
語(yǔ)法: if 條件1 then 語(yǔ)句1; elseif 條件2 then 語(yǔ)句2; .... else 語(yǔ)句n; end if; 功能:類似于多重if只能應(yīng)用在begin end 中

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

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:創(chuàng)建存儲(chǔ)過(guò)程,如果工資<2000,則刪除,如果5000>工資>2000,則漲工資1000,否則漲工資500

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)$

#案例1:創(chuàng)建函數(shù),實(shí)現(xiàn)傳入成績(jī),如果成績(jī)>90,返回A,如果成績(jī)>80,返回B,如果成績(jī)>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)控制:

iterate類似于 continue,繼續(xù),結(jié)束本次循環(huán),繼續(xù)下一次 leave 類似于 break,跳出,結(jié)束當(dāng)前所在的循環(huán)
  • while
語(yǔ)法: 【標(biāo)簽:while 循環(huán)條件 do循環(huán)體; end while【 標(biāo)簽】; 聯(lián)想: while(循環(huán)條件){循環(huán)體; }
  • loop
語(yǔ)法: 【標(biāo)簽:】loop循環(huán)體; end loop 【標(biāo)簽】;可以用來(lái)模擬簡(jiǎn)單的死循環(huán)
  • repeat
語(yǔ)法: 【標(biāo)簽:】repeat循環(huán)體; until 結(jié)束循環(huán)的條件 end repeat 【標(biāo)簽】;

1.沒(méi)有添加循環(huán)控制語(yǔ)句
#案例:批量插入,根據(jù)次數(shù)插入到admin表中多條記錄

DROP PROCEDURE pro_while1$ CREATE PROCEDURE pro_while1(IN insertCount INT) BEGINDECLARE i INT DEFAULT 1;WHILE i<=insertCount DOINSERT 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語(yǔ)句

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

TRUNCATE TABLE admin$ DROP PROCEDURE test_while1$ CREATE PROCEDURE test_while1(IN insertCount INT) BEGINDECLARE i INT DEFAULT 1;a:WHILE i<=insertCount DOINSERT 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語(yǔ)句

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

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)$int i=0; while(i<=insertCount){i++;if(i%2==0){continue;}插入 }

總結(jié)

以上是生活随笔為你收集整理的Mysql流程控制结构的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。