十六、MySQL流程控制結構(順序、分支、循環)詳解 & 強化練習

流程控制結構:順序、分支、循環

一、分支結構

case結構作爲表達式
在這裏插入圖片描述
case結構作爲獨立的語句
在這裏插入圖片描述

  1. if函數
    語法:if(條件,值1,值2)
    功能:實現雙分支
    應用在begin end中或外面

  2. case結構
    語法:

情況1:類似於java中的switch語句,一般用於實現等值判斷
case 變量或表達式或字段
when 要判斷的值1 then 返回的值1或語句1;
when 要判斷的值2 then 返回的值2或語句2;

else 要返回的值n或語句n;
end case;

情況2:類似於java中的多重if語句,一般用於實現區間判斷
case
when 要判斷的條件1 then 返回的值1或語句1;
when 要判斷的條件2 then 返回的值2或語句2;

else 要返回的值n或語句n;
end case;

應用在begin end 中或外面
特點:
1.可以作爲表達式,嵌套在其他語句中使用,可以放在任何地方,BEGIN END中 或 BEGIN END的外面;
可以作爲獨立的語句去使用,只能放在BEGIN END 中
2. 如果when中的值滿足或條件成立,則執行then 後面的語句,並且結束case
如果都不滿足,則執行else中的語句或值
3. ELSE可以省略,如果ELSE省略了,並且所有的when條件都不滿足,則返回NULL
在這裏插入圖片描述

  1. if結構
    語法:
    if 條件1 then 語句1;
    elseif 條件2 then 語句2;

    else 語句n;
    end if;
    功能:類似於多重if

只能應用在begin end 中

案例1:創建函數,實現傳入成績,如果成績>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:創建存儲過程,如果工資<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:創建函數,實現傳入成績,如果成績>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)$

二、循環結構

分類:
while、loop、repeat
在這裏插入圖片描述

循環控制:

iterate類似於 continue,繼續,結束本次循環,繼續下一次
leave 類似於 break,跳出,結束當前所在的循環

  1. while
    語法:
    【標籤:】while 循環條件 do
    循環體;
    end while【 標籤】;
聯想:
while(循環條件){
	循環體;
}
  1. loop,一般搭配循環控制條件leave來使用
    語法:
    【標籤:】loop
    循環體;
    end loop 【標籤】;

可以用來模擬簡單的死循環

  1. repeat
    語法:
    【標籤:】repeat
    循環體;
    until 結束循環的條件
    end repeat 【標籤】;

類似於do …while
do {
}while(循環條件);

1. 沒有添加循環控制語句

案例:批量插入,根據次數插入到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語句

案例:批量插入,根據次數插入到admin表中多條記錄,如果次數>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語句

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

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;
	}
	插入
	
}

三、強化練習

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

向該表插入指定個數的,隨機的字符串

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

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章