MySQL过程循环在一次迭代后停止

时间:2015-03-14 05:27:28

标签: mysql cursor procedure

我正在研究一个MySQL程序,它创建了我的一个表的摘要。该过程检索数据集并使用游标循环遍历它。对于循环的每次迭代,该过程更新另一个表。我遇到的问题是循环在单次迭代之后结束,虽然我知道我正在运行的查询检索多行。

BEGIN
  # Variable declaration section omitted for brevity


  DECLARE cur CURSOR FOR SELECT
    t.result_id,
    t.athlete_id, t.`first`, t.middle, `last`, t.pref, t.birth,t.uss,
    t.club_id,t.code,t.club_name,
    t.meet_name,t.meet_id,t.`start`,t.`end`,
    MIN(t.time) as time,t.age,t.type
     FROM sometable t GROUP BY club_id ORDER BY time asc,t.start desc,club_id;

  DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
  OPEN cur;

  read_loop: LOOP

    FETCH cur INTO result_id,athlete_id, first_name, middle, last_name, pref, birth,uss,
    club_id,club_code,club_name,
    meet_name,meet_id,start_date,end_date,
    result_time,age,type;

    IF done=1 THEN
      LEAVE read_loop;
    END IF;


    SET last_time = result_time;

    INSERT INTO toptimes(`result_id`,`club_id`,`agegroup`,`sex`,`distance`,`course`,`stroke`,`data`,`published`)
    VALUES(result_id,club_id,AgeGroupID,sex,distance,course,stroke,json,0);

  END LOOP read_loop;
  CLOSE cur;
END

我不清楚问题是什么。当我手动运行select查询时,我会返回几行。在循环中运行insert语句是否有问题?

1 个答案:

答案 0 :(得分:1)

你的代码块对我来说很好看。

你怎么知道它只运行一次迭代(我没有看到任何迭代) 打印或选择语句用于调试目的)? 执行存储过程时是否收到任何错误?

我试图用“sakila”数据库(mysql sample db)复制类似的代码。它工作得很好。如果它有帮助,请检查这个sql代码示例。

DROP PROCEDURE IF EXISTS usp_select_dummy_data ;

DELIMITER $$
CREATE DEFINER=`root`@`localhost` PROCEDURE usp_select_dummy_data()
BEGIN
-- Declare your variables
    Declare _var_actor_id int default 0;
    DECLARE _var_film_id int default 0;

-- Declare variable used for cursor and loop control
    DECLARE done int;
    DECLARE loop_counter INT DEFAULT 0;

-- Declare the cursor
     DECLARE cur CURSOR FOR
        SELECT
             actor_id, film_id
        FROM film_actor;

-- Declare handlers
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;

-- Open the cursor 
   OPEN cur ;

-- Start the loop
  read_loop: LOOP
    FETCH  cur
      INTO  _var_actor_id, _var_film_id ;

    -- break out of the loop if
    -- 1. if there is no rows or
    -- 2.  we've processed them all
     IF done = 1 THEN
       CLOSE cur ;
             LEAVE read_loop ;
      END IF;

    -- Count the number of times looped
       SET loop_counter = loop_counter + 1 ;

    END LOOP read_loop ;

-- print the loop count
 select loop_counter;
END