MySQL存储过程中的三种循环方式

“明月别枝惊鹊,清风半夜鸣蝉”
最近存储过程写得多,循环多数用在游标里,在这里总结几种循环的方式

CREATE DEFINER=`root`@`localhost` PROCEDURE `NewProc`()
BEGIN

    DECLARE startDate VARCHAR(20);  
    DECLARE endDate VARCHAR(20);
     declare i int;
     declare j int;
     set i=0;
     set j=0;
        #定义开始时间
    set startDate = '20180829';
    #定义结束时间
    set endDate = "20180831";

        -- 第一种,while循环
     while i < 3 do 
            select i;
--          i+1
            set i = i +1;
    end while;

    -- 第二种,repeat循环
    REPEAT
            select j;
            set j = j +1;
    UNTIL j > 3 

END REPEAT;

-- 第三种,loop循环
    test_loop: LOOP
    select startDate;
#开始时间加一天
    set startDate = DATE_FORMAT(date_add(startDate,interval 1 day),"%Y%m%d");
    IF startDate>endDate THEN
        LEAVE test_loop; 
    END IF; 
END LOOP test_loop;

END

再来看下,在游标中如何使用循环:

CREATE DEFINER=`root`@`localhost` PROCEDURE `NewProc`()
BEGIN
    #定义变量用于存储查询结果
    declare temp_id varchar(30);
    #这个用于处理游标到达最后一行的情况 
    DECLARE done INT DEFAULT 0;
    #声明游标cursor_name(cursor_name是个多行结果集)  
  DECLARE cursor_three CURSOR FOR 
        SELECT
            id
        FROM
            test_id;
    #设置一个终止标记(如果不要这句,会出现1329 - No data - zero rows fetched, selected, or processed错误信息)
    DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done=1;  
    #打开游标  
  OPEN cursor_three;

    #开始循环,判断是否游标已经到达了最后作为循环条件   
 REPEAT
 #获取游标当前指针的记录,读取一行数据并传给变量a,b  
  fetch cursor_three into temp_id;  
#输出查出来的ID
        select temp_id;
UNTIL done 
END REPEAT;
    #关闭游标
    CLOSE cursor_three ;

END

test_id这张表只有5条数据:
这里写图片描述
这个游标的存储过程输出结果为:
这里写图片描述

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值