case结构
case结构有两种语法:
作为表达式使用 ,嵌套在其他语句中使用,在 BEGIN-END 中和 BEGIN-END 外都可以使用。 作为独立的语句使用 ,只能放在 BEGIN-END 中。 如果省略ELSE,且所有的WHEN都不满足,则返回null。
特点:【演示case作为独立的语句】# 创建存储过程,根据传入的成绩,显示等级:90-100显示A 、 80-90显示B、60-80显示C、否则显示DCREATE PROCEDURE test_case(IN score INT)BEGIN CASE WHEN score>=90 AND score<=100 THEN SELECT 'A'; WHEN score>=80 THEN SELECT 'B'; WHEN score>=60 THEN SELECT 'C'; ELSE SELECT 'D'; END CASE;END $CALL test_case(95)$IF结构
语法:
if 条件1 then 语句1;
elseif 条件2 then 语句2;
...
[else 语句n;]
end if;【演示IF结构】# 根据传入的成绩,显示等级:90-100显示A 、 80-90显示B、60-80显示C、否则显示DCREATE FUNCTION test_if(score INT) RETURNS CHARBEGIN IF score>=90 AND score<=100 THEN RETURN 'A'; ELSEIF score>=80 THEN RETURN 'B'; ELSEIF score>=60 THEN RETURN 'C'; ELSE RETURN 'D'; END IF;END $SELECT test_if(61)$循环结构mysql中的循环结构有下面三种:
名称 语法 特点 while 先判断后执行 repeat ,类似Java中的do-wile语句 先执行后判断 loop 没有条件的死循环可以在循环控制中使用的关键字有 iterate (类似于Java中的continue)和 leave (类似于Java中的break)
【演示简单的循环结构】# 案例:批量插入,根据次数插入到admin表中多条记录.CREATE PROCEDURE pro_while1(IN insertCount INT)BEGIN DECLARE i INT DEFAULT 1; WHILE i<=insertCount DO INSERT INTO admin(username,PASSWORD) VALUES(CONCAT('Lili',i),'666'); SET i=i+1; END WHILE;END $CALL pro_while1(100)$--------------------------------------------------------------------------------------------【演示添加了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),'2333'); IF i>=20 THEN LEAVE a; END IF; SET i=i+1; END WHILE a;END $CALL test_while1(100)$--------------------------------------------------------------------------------------------【演示添加了iterate的语句】# 案例:批量插入,根据次数插入到admin表中,直插入偶数次CREATE PROCEDURE test_while2(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('ming',i),'777'); END WHILE a;END $CALL test_while2(100)$学习了mysql的流程控制,尝试完成下列习题
【习题答案】DROP TABLE IF EXISTS stringcontent;CREATE TABLE stringcontent( id INT PRIMARY KEY AUTO_INCREMENT, content VARCHAR(20) );DELIMITER $CREATE PROCEDURE test_pro1(IN insertCount INT)BEGIN DECLARE i INT DEFAULT 1;#定义一个循环变量i,表示插入次数 DECLARE str VARCHAR(26) DEFAULT 'abcdefghijklmnopqrstuvwxyz'; DECLARE strIndex INT DEFAULT 1;#代表起始索引 DECLARE len INT DEFAULT 1;#代表截取的字符的长度 WHILE i<=insertCount DO #两条生成随机数的指令原理相同:随机数*长度+1 SET len=FLOOR(RAND()*(20-strIndex+1)+1);#产生一个随机整数,代表起始索引1-26 SET strIndex=FLOOR(RAND()*20+1);#产生一个随机整数,代表截取长度(26-startIndex+1) INSERT INTO stringcontent(content) VALUES(SUBSTR(str,strIndex,len)); SET i=i+1;#循环变量更新 END WHILE;END $CALL test_pro1(10)$SELECT * FROM stringcontent$更多相关免费学习推荐: mysql教程 (视频)
以上就是MySQL精讲之六:流程控制的详细内容!
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did93047
MySQL精讲之六:流程控制
阅读:46次