• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

mysql procedure存储过程循环,条件判断范例

mysql 搞代码 4年前 (2022-01-09) 20次浏览 已收录 0个评论

mysql procedure存储过程循环,条件判断实例 本文转载自:???? http://www.111cn.net/database/mysql/38878.htm ? ? mysql教程 procedure存储过程循环,条件判断实例 ? mysql delimiter $$ mysql CREATE PROCEDURE myProc() ??? – DETERMINISTIC ??? – BEGIN ?

mysql procedure存储过程循环,条件判断实例

本文转载自:???? http://www.111cn.net/database/mysql/38878.htm

?

?

mysql教程 procedure存储过程循环,条件判断实例

?

mysql> delimiter $$
mysql> CREATE PROCEDURE myProc()
??? -> DETERMINISTIC
??? -> BEGIN
??? ->?? DECLARE counter INT DEFAULT 0;
??? ->
??? ->?? simple_loop: LOOP
??? ->???? SET counter=counter+1;
??? ->???? select counter;
??? ->???? IF counter=10 THEN
??? ->??????? LEAVE simple_loop;
??? ->???? END IF;
??? ->?? END LOOP simple_loop;
??? ->?? SELECT ‘I can count to 10’;
??? -> END$$
Query OK, 0 rows affected (0.00 sec)

mysql>
mysql> delimiter ;
mysql>
mysql> call myProc();
+———+
| counter |
+———+
|?????? 1 |
+———+
1 row in set (0.00 sec)

+———+
| counter |
+———+
|?????? 2 |
+———+
1 row in set (0.02 sec)

+———+
| counter |
+———+
|?????? 3 |
+———+
1 row in set (0.02 sec)

+———+
| counter |
+———+
|?????? 4 |
+———+
1 row in set (0.02 sec)

+———+
| counter |
+———+
|?????? 5 |
+———+
1 row in set (0.02 sec)

+———+
| counter |
+———+
|?????? 6 |
+———+
1 row in set (0.02 sec)

+———+
| counter |
+———+
|?????? 7 |
+———+
1 row in set (0.02 sec)

+———+
| counter |
+———+
|?????? 8 |
+———+
1 row in set (0.02 sec)

+———+
| counter |
+———+
|?????? 9 |
+———+
1 row in set (0.33 sec)

+———+
| counter |
+———+
|????? 10 |
+———+
1 row in set (0.33 sec)

+——————-+
| I can count to 10 |
+——————-+
| I can count to 10 |
+——————-+
1 row in set (0.33 sec)

Query OK, 0 rows affected (0.33 sec)

实例二

mysql> CREATE PROCEDURE myProc()本文来源gao@!dai!ma.com搞$$代^@码!网!
??? -> BEGIN
??? ->???? DECLARE i int;
??? ->???? SET i=1;
??? ->???? myloop: LOOP
??? ->????????? SET i=i+1;
??? ->????????? IF i=10 THEN
??? ->?????????????????? LEAVE myloop;
??? ->????????? END IF;
??? ->???? END LOOP myloop;
??? ->???? SELECT ‘I can count to 10’;
??? ->
??? -> END$$
Query OK, 0 rows affected (0.00 sec)

mysql>
mysql> delimiter ;
mysql>
mysql> call myProc();
+——————-+
| I can count to 10 |
+——————-+
| I can count to 10 |
+——————-+
1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec

带有条件

mysql> create procedure increment (IN in_count INT)
??? -> BEGIN
??? -> declare count INT default 0;
??? ->
??? ->???? increment: loop
??? ->???????? set count = count + 1;
??? ->???????? if count < 20 then
??? ->???????????? iterate increment;
??? ->???????? end if;
??? ->???????? if count > in_count then
??? ->???????????? leave increment;
??? ->???????? end if;
??? ->???? end loop increment;
??? ->???? select count;
??? -> END
??? -> //
Query OK, 0 rows affected (0.00 sec)

mysql>
mysql> delimiter ;
mysql> call increment(3);
+——-+
| count |
+——-+
|??? 20 |
+——-+
1 row in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

?

?

?

?

?


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql procedure存储过程循环,条件判断范例

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址