存儲過程(1)mysql中游標的使用

CREATE PROCEDURE `test`.`new_procedure` ()
BEGIN
-- 需要定義接收遊標數據的變量 
  DECLARE a CHAR(16);
  -- 遊標
  DECLARE cur CURSOR FOR SELECT i FROM test.t;
  -- 遍歷數據結束標誌
  DECLARE done INT DEFAULT FALSE;
  -- 將結束標誌綁定到遊標
  DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
  -- 打開遊標
  OPEN cur;
  -- 開始循環
  read_loop: LOOP
    -- 提取遊標裏的數據,這裏只有一個,多個的話也一樣;
    FETCH cur INTO a;
    -- 聲明結束的時候
    IF done THEN
      LEAVE read_loop;
    END IF;
    -- 這裏做你想做的循環的事件
    INSERT INTO test.t VALUES (a);
  END LOOP;
  -- 關閉遊標
  CLOSE cur;
END


這裏有一個比較坑的地方,注意,變量的定義不要和你的select的列的鍵同名!不然,fetch into 會失敗!

fetch into 也可以按照查詢出來的字段依次賦值給不同變量 : FETCH cur_test INTO a1,a2,a3,a4,a5;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章