html5 网站正在建设中,怎么叫人做网站,浙江网站建设培训机构,南阳网站建设培训目录
while
介绍
案例
repeat
介绍
案例
loop
介绍
案例一
案例二 while 介绍
while 循环是有条件的循环控制语句。满足条件后#xff0c;再执行循环体中的SQL语句。具体语法为#xff1a;
-- 先判定条件#xff0c;如果条件为true#xff0c;则执行逻辑#…目录
while
介绍
案例
repeat
介绍
案例
loop
介绍
案例一
案例二 while 介绍
while 循环是有条件的循环控制语句。满足条件后再执行循环体中的SQL语句。具体语法为
-- 先判定条件如果条件为true则执行逻辑否则不执行逻辑WHILE 条件 DOSQL逻辑...END WHILE;
案例
计算从1累加到n的值n为传入的参数值。
-- A. 定义局部变量, 记录累加之后的值;
-- B. 每循环一次, 就会对n进行减1 , 如果n减到0, 则退出循环create procedure p(in n int)
begindeclare total int default 0;while n0 doset total : total n;set n : n - 1;end while;select total;end;call p(100); repeat 介绍
repeat是有条件的循环控制语句, 当满足until声明的条件的时候则退出循环 。具体语法为
-- 先执行一次逻辑然后判定UNTIL条件是否满足如果满足则退出。
-- 如果不满足则继续下一次循环REPEATSQL逻辑...UNTIL 条件END REPEAT;
案例
计算从1累加到n的值n为传入的参数值。(使用repeat实现)
-- A. 定义局部变量, 记录累加之后的值;
-- B. 每循环一次, 就会对n进行-1 , 如果n减到0, 则退出循环create procedure p(in n int)
begindeclare total int default 0;repeatset total : total n;set n : n - 1;until n 0end repeat;select total;end;call p(10);
call p(100); loop 介绍
LOOP 实现简单的循环如果不在SQL逻辑中增加退出循环的条件可以用其来实现简单的死循环。 LOOP可以配合一下两个语句使用
LEAVE 配合循环使用退出循环。ITERATE必须用在循环中作用是跳过当前循环剩下的语句直接进入下一次循环。
[begin_label:] LOOPSQL逻辑...END LOOP [end_label];
LEAVE label; -- 退出指定标记的循环体ITERATE label; -- 直接进入下一次循环
上述语法中出现的 begin_labelend_labellabel 指的都是我们所自定义的标记可以自己进行命名。
案例一
计算从1累加到n的值n为传入的参数值。
-- A. 定义局部变量, 记录累加之后的值;
-- B. 每循环一次, 就会对n进行-1 , 如果n减到0, 则退出循环 ---- leave xxcreate procedure p(in n int)
begindeclare total int default 0;sum:loopif n0 thenleave sum;end if;set total : total n;set n : n - 1;end loop sum;select total;end;call p(100);案例二
计算从1到n之间的偶数累加的值n为传入的参数值。
-- A. 定义局部变量, 记录累加之后的值;
-- B. 每循环一次, 就会对n进行-1 , 如果n减到0, 则退出循环 ---- leave xx
-- C. 如果当次累加的数据是奇数, 则直接进入下一次循环. -------- iterate xxcreate procedure p(in n int)
begindeclare total int default 0;sum:loopif n0 thenleave sum;end if;if n%2 1 thenset n : n - 1;iterate sum;end if;set total : total n;set n : n - 1;end loop sum;select total;end;call p(100); END 学习自黑马程序员——MySQL数据库课程