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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

十六、MySQL流程控制结构(顺序、分支、循环)详解 强化练习

發布時間:2024/7/5 数据库 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 十六、MySQL流程控制结构(顺序、分支、循环)详解 强化练习 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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

一、分支結構

case結構作為表達式

case結構作為獨立的語句

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

  • 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

  • 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 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

    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:創建函數,實現傳入成績,如果成績>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,跳出,結束當前所在的循環

  • while
    語法:
    【標簽:】while 循環條件 do
    循環體;
    end while【 標簽】;
  • 聯想: while(循環條件){循環體; }
  • loop,一般搭配循環控制條件leave來使用
    語法:
    【標簽:】loop
    循環體;
    end loop 【標簽】;
  • 可以用來模擬簡單的死循環

  • repeat
    語法:
    【標簽:】repeat
    循環體;
    until 結束循環的條件
    end repeat 【標簽】;
  • 類似于do …while
    do {
    }while(循環條件);

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

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

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

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

    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) BEGINDECLARE i INT DEFAULT 1;DECLARE str VARCHAR(26) DEFAULT 'abcdefghijklmnopqrstuvwxyz';DECLARE startIndex INT;#代表初始索引DECLARE len INT;#代表截取的字符長度WHILE i<=insertcount DOSET startIndex=FLOOR(RAND()*26+1);#代表初始索引,隨機范圍1-26SET 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)$

    創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

    總結

    以上是生活随笔為你收集整理的十六、MySQL流程控制结构(顺序、分支、循环)详解 强化练习的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。