本文实例讲述了mysql存储过程之循环语句(WHILE,REPEAT和LOOP)用法。分享给大家供大家参考,具体如下:

MySQL提供循环语句,允许我们根据条件重复执行一个SQL代码块其中有三个循环语句:WHILE,REPEAT和LOOP,我们接下来分别看下。首先是WHILE语句来看下语法:

WHILE expression DO  statementsEND 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 ;
CALL test_mysql_while_loop();
mysql> CALL test_mysql_while_loop();+------------+| str    |+------------+| 1,2,3,4,5, |+------------+1 row in setQuery OK, 0 rows affected
REPEAT statements;UNTIL expressionEND 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 ;
mysql> CALL mysql_test_repeat_loop();+------------+| str    |+------------+| 1,2,3,4,5, |+------------+1 row in setQuery OK, 0 rows affected
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;
  • 以上存储过程仅构造具有偶数字符串的字符串,例如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 setQuery 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数据库计有所帮助。

更多相关文章

  1. Android(安卓)-- Android(安卓)JUint 与 Sqlite
  2. android 当系统存在多个Launcher时,如何设置开机自动进入默认的La
  3. Android(安卓)SQLiteDatabase的使用
  4. android 通话记录次数
  5. Android(安卓)SQLiteDatabase的使用
  6. android实现关键字搜索功能
  7. 我的android 第14天 - 使用SQLiteDatabase操作SQLite数据库
  8. Android(安卓)编码规范
  9. android contentProvider例子

随机推荐

  1. 如何部署Bower安装的软件包?
  2. 用WordPress决定jQuery的版本?
  3. jQuery无法从localhost检索数据
  4. 如何使用jquery ajax获取api数据?
  5. 用jquery 绑定一个按钮click事件后,第一次
  6. Jquery中的队列函数quene()、dequene()、
  7. JQUERY中做表单验证,谁有带时间的日期选择
  8. 请问jquery如何选择tr下的n个tr?
  9. 如何检测jQuery中的水平滚动?
  10. jquery自定义事件