暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

关于MySQL循环的解读

菜鸟也有梦想 2019-04-23
188

mysql中有下面几种循环

WHILE……DO……END WHILE
REPEAT……UNTIL END REPEAT
LOOP……END LOOP
GOTO


下面来看看我们的具体方法吧

关于while 循环

一 、 while 循环


delimiter $$    // 定义结束符为 $$
drop procedure if exists abd; // 删除 已有的 存储过程
create procedure abd()      //  创建新的存储过程
begin
declare i int;          // 变量声明
set i = 1;     
while i < 20 do           // 循环体
insert into user_profile (uid) values (i);
set i = i +1;
end while;
end $$               // 结束定义语句


// 调用

delimiter ;          
// 先把结束符 回复为;

call abd();

delimter : mysql 默认的 delimiter是; 告诉mysql解释器,该段命令是否已经结束了,mysql是否可以执行了。

这里使用 delimiter 重定义结束符的作用是:不让存储过程中的语句在定义的时候输出。


创建 MySQL 存储过程的简单语法为:

CREATE PROCEDURE 存储过程名称( [in | out | inout] 参数 )
BEGIN
Mysql 语句
END
call 存储过程名称()


二 、 REPEAT 循环

delimiter //
drop procedure if exists looppc;
create procedure looppc()
begin
declare i int;
set i = 1;

repeat
insert into user_profile_company (uid) values (i+1);
set i = i + 1;
until i
>= 20

end repeat;


end

call looppc()


复制

三、 LOOP 循环


delimiter $$
drop procedure if exists lopp;
create procedure lopp()
begin
declare i int ;
set i = 1;

lp1 : LOOP              
// lp1 为循环体名称 LOOP 为关键字
insert into user_profile (uid) values (i);
set i = i+1;
if i > 30 then
leave lp1;              
// 离开循环体
end if;
end LOOP;              // 结束循环
end $$
复制


文章转载自菜鸟也有梦想,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论