mysql存储过程之循环语句(WHILE,REPEAT和LOOP)
⽤法分析
本⽂实例讲述了mysql存储过程之循环语句(WHILE,REPEAT和LOOP)⽤法。分享给⼤家供⼤家参考,具体如下:
MySQL提供循环语句,允许我们根据条件重复执⾏⼀个SQL代码块其中有三个循环语句:WHILE,REPEAT和LOOP,我们接下来分别看下。⾸先是WHILE语句来看下语法:
WHILE expression DO
statements
END WHILE
WHILE循环在每次迭代开始时检查表达式。如果expressionevaluates为TRUE,MySQL将执⾏WHILE和END WHILE之间的语句,直到expressionevaluates为FALSE。 WHILE循环称为预先测试条件循环,因为它总是在执⾏前检查语句的表达式。来看下流程图:
完事咱们尝试在存储过程中使⽤WHILE循环语句,看个实例:
DELIMITER $$
DROP PROCEDURE IF EXISTS test_mysql_while_loop$$
CREATE PROCEDURE test_mysql_while_loop()
BEGIN
DECLARE x INT;
DECLARE str VARCHAR(255);
SET x = 1;
SET str = '';
汪兆镛
WHILE x <= 5 DO
SET str = CONCAT(str,x,',');
手抄党章
SET x = x + 1;
END WHILE;
SELECT str;
END$$
DELIMITER ;
在上⾯的test_mysql_while_loop存储过程中,它的操作是先来重复构建str字符串,直到x变量的值⼤于5,完事使⽤lect语句显⽰最终的字符串。我们要注意的是,如果不初始化x变量的值,那么它默认值为NULL。因此,WHILE循环语句中的条件始终为TRUE,并且我们将有⼀个不确定的循环,这是不可预料的。废话不多说,我们先来调⽤test_mysql_while_loopstored存储过程:
CALL test_mysql_while_loop();
执⾏上⾯查询语句,得到以下结果:
mysql> CALL test_mysql_while_loop();
+------------+
美女曝光图
| str |
扬子洗衣机
+------------+
| 1,2,3,4,5, |
+------------+
1 row in t
Query OK, 0 rows affected
完事再来看REPEAT循环语句的语法结构:
REPEAT
statements;
UNTIL expression
END REPEAT
上述sql⾸先被mysql执⾏,完事mysql会评估求值表达式(expression),如果表达式(expression)的计算结果为FALSE,则mysql将重复执⾏该语句,直到该表达式计算结果为TRUE。因为REPEAT循环语句在执⾏语句后检查表达式(expression),因此REPEAT循环语句也称为测试后循环。咱们来看下流程图:
完事咱们再来使⽤REPEAT循环语句重写test_mysql_while_loop存储过程:
DELIMITER $$
DROP PROCEDURE IF EXISTS mysql_test_repeat_loop$$
CREATE PROCEDURE mysql_test_repeat_loop()
BEGIN
DECLARE x INT;
DECLARE str VARCHAR(255);
SET x = 1;
SET str = '';
REPEAT
SET str = CONCAT(str,x,',');
SET x = x + 1;
UNTIL x > 5
END REPEAT;
重阳节的起源SELECT str;
END$$
DELIMITER ;
etc收费我们要注意的是UNTIL表达式中没有分号(;)。执⾏上⾯查询语句,得到以下结果:
mysql> CALL mysql_test_repeat_loop();
三年级下册
+------------+
| str |
+------------+
| 1,2,3,4,5, |
+------------+
1 row in t
Query OK, 0 rows affected
最后咱们再来看⼀个使⽤LOOP循环语句的⽰例:
CREATE PROCEDURE test_mysql_loop()
BEGIN
DECLARE x INT;
DECLARE str VARCHAR(255);
SET x = 1;
SET str = '';
loop_label: LOOP
IF x > 10 THEN
LEAVE loop_label;
END IF;
SET x = x + 1;
IF (x mod 2) THEN
ITERATE loop_label;
ELSE
SET str = CONCAT(str,x,',');
END IF;
END LOOP;
SELECT str;
END;
上述sql具体作⽤如下:
以上存储过程仅构造具有偶数字符串的字符串,例如2,4,6等。
在LOOP语句之前放置⼀个loop_label循环标签。
如果x的值⼤于10,则由于LEAVE语句,循环被终⽌。
如果x的值是⼀个奇数,ITERATE语句忽略它下⾯的所有内容,并开始⼀个新的迭代。
如果x的值是偶数,则ELSE语句中的块将使⽤偶数构建字符串。
赵丽颖花千骨图片
执⾏上⾯查询语句,得到以下结果:
mysql> CALL test_mysql_loop();
+-------------+
| str |
+-------------+
| 2,4,6,8,10, |
+-------------+
1 row in t
Query OK, 0 rows affected
完事咱们再来看下控制循环的两个关键词:
LEAVE语句⽤于⽴即退出循环,⽽⽆需等待检查条件。LEAVE语句的⼯作原理就类似PHP,C/C++,java等其他语⾔的break语句⼀样。
ITERATE语句允许您跳过剩下的整个代码并开始新的迭代。ITERATE语句类似于PHP,C/C++,Java等中的continue 语句。
好啦,本次记录就到这⾥了。
更多关于MySQL相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》及《》
希望本⽂所述对⼤家MySQL数据库计有所帮助。