在MySQL存储过程的语句中有三个标准的循环方式
来源:互联网 发布:java写一个计算器 编辑:程序博客网 时间:2024/06/05 11:50
在MySQL存储过程的语句中有三个标准的循环方式:WHILE循环,LOOP循环以及REPEAT循环。还有一种非标准的循环方式:GOTO,不过这种循环方式最好别用,很容易引起程序的混乱,在这里就不错具体介绍了。
这几个循环语句的格式如下:
WHILE……DO……END WHILE
REPEAT……UNTIL END REPEAT
LOOP……END LOOP
GOTO。
mysql> create procedure pro10()
Query OK, 0 rows affected (0.00 sec)
mysql> delete from t1//
Query OK, 0 rows affected (0.00 sec)
mysql> call pro10()//
Query OK, 1 row affected (0.00 sec)
mysql> select * from t1//
+——-+
| filed |
+——-+
|
|
|
|
|
+——-+
5 rows in set (0.00 sec)
mysql> create procedure pro11()
Query OK, 0 rows affected (0.00 sec)
mysql> delete from t1//
Query OK, 5 rows affected (0.00 sec)
mysql> call pro11()//
Query OK, 1 row affected (0.00 sec) #虽然在这里显示只有一行数据受到影响,但是下面选择数据的话,还是插入了5行数据。
mysql> select * from t1//
+——-+
| filed |
+——-+
|
|
|
|
|
+——-+
5 rows in set (0.00 sec)
一行就是执行结果,实际的作用和使用while编写的存储过程一样,都是插入5行数据。
再来看一下第三个循环控制语句LOOP……END LOOP。编写一个存储过程程序如下:
mysql> create procedure pro12()
Query OK, 0 rows affected (0.00 sec)
从上面这个例子可以看出,使用LOOP编写同样的循环控制语句要比使用while和repeat编写的要复杂一些:在循环内部加入了IF……END IF语句,在IF语句中又加入了LEAVE语句,LEAVE语句的意思是离开循环,LEAVE的格式是:LEAVE 循环标号。
mysql> delete from t1//
Query OK, 5 rows affected (0.00 sec)
mysql> call pro12//
Query OK, 1 row affected (0.00 sec) #虽然说只有一行数据受影响,但是实际上是插入了5行数据。
mysql> select * from t1//
+——-+
| filed |
+——-+
|
|
|
|
|
+——-+
5 rows in set (0.00 sec)
mysql> create procedure pro13()
Query OK, 0 rows affected (0.00 sec)
mysql> create procedure pro14()
Query OK, 0 rows affected (0.00 sec)
ITERATE 迭代
mysql> create procedure pro15()
Query OK, 0 rows affected (0.00 sec)
mysql> delete from t1//
Query OK, 5 rows affected (0.00 sec)
mysql> call pro15//
Query OK, 1 row affected (0.00 sec)
mysql> select * from t1//
+——-+
| filed |
+——-+
|
|
|
|
+——-+
4 rows in set (0.00 sec)
和我们上面分析的结果一样,只插入了数值0,1,2,4。
- 在MySQL存储过程的语句中有三个标准的循环方式
- mysql三个标准的循环方式
- MySQL存储过程中使用 WHILE 循环语句的用法
- mysql的存储过程中的语句if case 循环语句
- db2存储过程中循环语句while do的continue有没有?
- 存储过程的循环语句
- Oracle中查询有哪些存储过程的sql语句
- MySQL 存储过程中使用 WHILE 循环语句
- mysql-存储过程-插入数据数-测试在select语句中in和or的区别
- 在SQL SERVER 2005存储过程中,使用循环语句
- 在存储过程中执行3种oracle循环语句
- 在存储过程中执行3种oracle循环语句
- 在SQL SERVER 2005存储过程中,使用循环语句
- 在存储过程中执行3种oracle循环语句
- 在存储过程中执行oracle循环语句
- mysql存储过程中常用的一些功能性语句
- 在SQL 语句中使用存储过程的结果集
- MySql循环插入的存储过程
- 第9周-项目2-我的数组类
- Android : The import java.util cannot be resolved
- CI 配置 新浪云mysql数据库
- 第九周上机时间项目——项目3-人数不定的工资类
- 移动前端第二弹:善用meta
- 在MySQL存储过程的语句中有三个标准的循环方式
- 第9周项目1:深复制体验(1)
- 第十,十一周-阅读项目-继承与派生
- 编程小练习
- 第八周项目训练2
- 金山快盘将停止个人用户存储服务 转型个人视频服务
- 类和指针(1)
- 易經大意 441_460
- 【项目管理和构建】——Maven下载、安装和配置