添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
更新时间:2019年12月18日 09:42:36   作者:luyaran
这篇文章主要介绍了mysql存储过程之循环语句(WHILE,REPEAT和LOOP)用法,结合实例形式分析了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,完事使用select语句显示最终的字符串。我们要注意的是,如果不初始化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 set 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 ;

我们要注意的是UNTIL表达式中没有分号(;)。执行上面查询语句,得到以下结果:

mysql> CALL mysql_test_repeat_loop(); +------------+ | str | +------------+ | 1,2,3,4,5, | +------------+ 1 row in set 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; SET str = CONCAT(str,x,','); END IF; END LOOP; SELECT str;

上述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 set Query OK, 0 rows affected

    完事咱们再来看下控制循环的两个关键词:

  • LEAVE语句用于立即退出循环,而无需等待检查条件。LEAVE语句的工作原理就类似PHP,C/C++,java等其他语言的break语句一样。
  • ITERATE语句允许您跳过剩下的整个代码并开始新的迭代。ITERATE语句类似于PHP,C/C++,Java等中的continue语句。
  • 好啦,本次记录就到这里了。

    更多关于MySQL相关内容感兴趣的读者可查看本站专题:《 MySQL存储过程技巧大全 》、《 MySQL常用函数大汇总 》、《 MySQL日志操作技巧大全 》、《 MySQL事务操作技巧汇总 》及《 MySQL数据库锁相关技巧汇总

    希望本文所述对大家MySQL数据库计有所帮助。

    您可能感兴趣的文章:
    • 关于Mysql自增id的这些你可能还不知道

      关于Mysql自增id的这些你可能还不知道

      这篇文章主要给大家介绍了关于Mysql自增id的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
      2019-05-05
    • 浅谈MySQL之select优化方案

      浅谈MySQL之select优化方案

      我们是否看到过在公司中许多查询语句都是select * xxxx,本文就主要介绍了MySQL之select优化方案,具有一定的参考价值,感兴趣的可以了解一下
      2021-08-08
    • mysql中多表删除其中ID相同记录的方法

      mysql中多表删除其中ID相同记录的方法

      这篇文章主要介绍了mysql中多表删除其中ID相同记录的方法,需要的朋友可以参考下
      2014-04-04
    • 深入分析MySQL数据类型 DECIMAL

      深入分析MySQL数据类型 DECIMAL

      这篇文章主要介绍了MySQL数据类型 DECIMAL的相关资料,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
      2020-09-09
    • 你还在 Select * 吗?

      你还在 Select * 吗?

      这篇文章主要介绍了MySql Select ,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
      2019-03-03
    • MySQL唯一索引和普通索引选哪个?

      MySQL唯一索引和普通索引选哪个?

      这篇文章主要介绍了MySQL唯一索引和普通索引的优劣,帮助大家更好的理解和使用MySQL索引,感兴趣的朋友可以了解下
      2020-10-10
    • mysqld-nt: Out of memory (Needed 1677720 bytes)解决方法

      mysqld-nt: Out of memory (Needed 1677720 bytes)解决方法

      这篇文章主要介绍了mysqld-nt: Out of memory (Needed 1677720 bytes)解决方法,需要的朋友可以参考下
      2014-12-12
    • MySQL如何优化查询速度

      MySQL如何优化查询速度

      这篇文章主要介绍了MySQL如何优化查询速度,帮助大家提升自己的数据库性能,感兴趣的朋友可以了解下
      2020-08-08
    • Mysql临时表原理及创建方法解析

      Mysql临时表原理及创建方法解析

      这篇文章主要介绍了Mysql临时表原理及创建方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
      2019-12-12
    • mysql命令行下用户管理方法分享

      mysql命令行下用户管理方法分享

      如果有mysql管理工具phpmyadmin的话,我们可以通过图形画界面来对用户进行管理,但是如果没有phpmyadmin这样的管理工具怎么办呢
      2012-07-07