本文摘自PHP中文网,作者coldplay.xixi,侵删。
免费学习推荐:mysql视频教程
文章目录
mysql中的流程控制和其他编程语言中的类似,也分为三种:顺序结构
、分支结构
、循环结构
。前几篇文章中用到的基本上都是顺序结构(除了IF函数),下面主要针对分支结构和循环结构进行介绍。
分支结构
IF函数
语法:IF(表达式1,表达式2,表达式3)
说明:如果表达式1成立,则执行表达式2,否则执行表达式3
case结构
case结构有两种语法:
特点:
- 作为表达式使用,嵌套在其他语句中使用,在
BEGIN-END
中和BEGIN-END
外都可以使用。 - 作为独立的语句使用,只能放在
BEGIN-END
中。 - 如果省略ELSE,且所有的WHEN都不满足,则返回null。
1 2 3 4 5 6 7 | 【演示 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;
1 2 3 4 5 6 | 【演示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)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | 【演示简单的循环结构】# 案例:批量插入,根据次数插入到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的流程控制,尝试完成下列习题
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | 【习题答案】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精讲之六:流程控制的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
什么是mysql innodb事务隔离级别?
deepin v20如何安装mysql
mysql的tar包移动和解压及创建一个mysql的用户
怎么改mysql数据库的名字
mysql数据库简介与基本操作
如何设置mysql服务开机不启动?
mysql如何允许外网访问设置
详解mysql中url时区的陷阱该如何规避
phpmyadmin #1045错误无法登录mysql服务器怎么办?
mysql中常见的8种sql错误用法
更多相关阅读请进入《mysql》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » MySQL精讲之六:流程控制