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 會失敗!

另外 :

如果沒有則插入數據,如果有則更新的方法:

insert into `test` values (a,b) ON DUPLICATE KEY UPDATE `a`=c;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM