-
MySQL教程之流程控制语句(MySQL/MariaDB )(2)
delimiter $$
create or replace procedure proc2(n int)
begin
declare i,sum int default 0;
my_loop: loop
set i=i+1;
if i>n then
leave my_loop;
elseif mod(i,2)=0 then
iterate my_loop;
else
set sum=i+sum;
end if;
end loop;
select sum;
end$$
delimiter ;
调用存储过程来测试。
CALL proc4(9);
sum
--------
25
虽然在MariaDB中,loop能单独定义在存储程序之外,但是由于定义在外面的时候无法打标签,而退出循环的leave却必须接标签才能退出loop,因此loop定义在存储程序之外完全是一个鸡肋的功能。同理,repeat和while也是一样的。
6.repeat循环
loop循环结构中没有退出循环的条件,只能人为书写条件判断语句来判断何时退出循环。而repeat循环结构提供了直接定义退出循环条件的功能。
[begin_label:] REPEAT
statement_list
UNTIL search_condition
END REPEAT [end_label]
其中until部分定义的是退出循环的条件。注意,until语句后面不需要结束提示符,给出了结束符反而报错。
例如下面的存储过程中,当a变量等于传入参数i的时候退出循环。
delimiter $$
create or replace procedure proc5(i int)
begin
declare a int default 1;
declare sum int default 1;
addnum: repeat
set a=a+1;
if mod(a,2)=1 then
set sum=sum+a;
end if;
until a=i
end repeat addnum;
select sum;
end$$
delimiter ;
call proc5(10);
sum
--------
25
7.while循环
while循环和repeat循环使用方法一样,但是思路不一样。repeat是满足条件时退出,而while是满足条件时才执行循环中定义的语句。
[begin_label:] WHILE search_condition DO
statement_list
END WHILE [end_label]
例如下面的存储过程,仍然是计算传入值范围内的奇数和。但使用的是while循环。
DROP PROCEDURE IF EXISTS proc6;
DELIMITER $$
CREATE PROCEDURE proc6(i INT)
BEGIN
SET @a=1,@sum=1;
addnum: WHILE @a<i DO
SET @a=@a+1;
IF MOD(@a,2)=1 THEN
SET @sum=@a+@sum;
END IF;
END WHILE addnum;
SELECT @sum AS SUM;
END$$
DELIMITER ;
本文原创地址在博客园:https://www.cnblogs.com/f-ck-need-u/p/8724063.html
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式