
免费学习推荐:mysql视频教程
文章目录
分支结构IF函数case结构IF结构循环结构
mysql中的流程控制和其他编程语言中的类似,也分为三种:顺序结构、分支结构、循环结构。前几篇文章中用到的基本上都是顺序结构(除了IF函数),下面主要针对分支结构和循环结构进行介绍。
分支结构
IF函数
语法:IF(表达式1,表达式2,表达式3)
说明:如果表达式1成立,则执行表达式2,否则执行表达式3
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)BEGINCASEWHEN score>=90 AND 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 CHARBEGINIF score>=90 AND 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)BEGINDECLARE i INT DEFAULT 1;WHILE i20则停止TRUNCATE TABLE admin$DROP PROCEDURE test_while1$CREATE PROCEDURE test_while1(IN insertCount INT)BEGINDECLARE i INT DEFAULT 1;a:WHILE 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)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('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)BEGINDECLARE 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#两条生成随机数的指令原理相同:随机数*长度+1SET len=FLOOR(RAND()*(20-strIndex+1)+1);#产生一个随机整数,代表起始索引1-26SET 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精讲之六:流程控制的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/188194.html
微信扫一扫
支付宝扫一扫