首页 > 数据库技术 > 详细

mysql 循环控制

时间:2015-06-27 21:23:22      阅读:302      评论:0      收藏:0      [点我收藏+]

1、使用while
DROP PROCEDURE IF EXISTS `addstudent`;
DELIMITER ;;
CREATE PROCEDURE `addstudent`(iNum int)
BEGIN
declare vI int default 0;

start transaction;

while(vI < iNum) do
insert into student(id,name) values(vI,concat(‘Andy‘,vI));
set vI = vI+1;
end while;

commit;
END
;;
DELIMITER ;
2、使用repeat
BEGIN
declare vI int default 0;

start transaction;

repeat
insert into student(id,name) values(vI,concat(‘Andy‘,vI));
set vI = vI+1;
until vI >= iNum end repeat;

commit;
END


3、使用loop
BEGIN
declare vI int default 0;

start transaction;

label_insert: LOOP

insert into student(id,name) values(vi,concat(‘Andy‘,vi));
set vI = vI+1;
if(vI >= iNum) then
leave label_insert;
end if;

end LOOP label_insert;

commit;
END
4、考虑下面的需求,在编程语言中循环控制中有continue,如何实现continue的功能?
使用 iterate label_insert; 对于LOOP如下:
BEGIN
declare vI int default 0;

start transaction;

label_insert: LOOP

if(vI=2) then
set vI = vI+1;
iterate label_insert;
end if;

insert into student(id,name) values(vi,concat(‘Andy‘,vi));
set vI = vI+1;
if(vI >= iNum) then
leave label_insert;
end if;

end LOOP label_insert;

commit;
END

注意:对于while和repeat也是同样的道理,但是需要在while和repeat 前面增加一个标签,表示再次循环的位置,如下:
label_insert: while
label_insert: repeat
mysql中暂时没有for循环。

mysql 循环控制

原文:http://www.cnblogs.com/nzbbody/p/4604609.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!